1. Nachrichten
  2. Forum
    1. Unerledigte Themen
    2. Forenregeln
  3. Spenden
  • Anmelden
  • Registrieren
  • Suche
Alles
  • Alles
  • Artikel
  • Seiten
  • Forum
  • Erweiterte Suche
  1. camp-firefox.de
  2. universum123

Beiträge von universum123

  • Fx 58 Nightly "Downloads"

    • universum123
    • 15. Dezember 2017 um 15:40

    so *push* <;)

    ich hab da was "entdeckt" im github

    saveFolderModoki.uc.js

    Save Folder

    XML
    <?xml version="1.0"?>
    
    
    <overlay id="saveFolderModokiOverlay" xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">
    <!--
    // ==UserScript==
    // @name           saveFolderModoki40.uc.js
    // @namespace      http://space.geocities.yahoo.co.jp/gl/alice0775
    // @description    saveFolderModoki
    // @include        main
    // @compatibility  Firefox 40+ non-e10s
    // @author         Alice0775
    // @version        2015/08/12 18:00 Fixed due to Bug 1134769
    // @version        2015/04/08 12:30 focusedWindow
    // @version        2014/11/26 21:00 Bug 1103280, Bug 704320
    // @version        2013/05/02 01:00 Bug 789546
    // @version        2013/04/14 21:00 checking element using Ci.nsIImageLoadingContent instead of HTMLImageElement
    // @version        2013/02/09 23:00 Bug 622423
    // @version        2011/10/06 23:00 Bug 795065 Add privacy status to nsDownload
    // ==/UserScript==
    // @version        2010/04/21 01:00 Firefox3.7a5pre
    // @version        2009/04/10 00:00 Minefield3.6a1pre での動作改善 (メニューのidが"SaveFolder"だとダメ なぜ?)
    // @version        2008/10/17 12:00 コード整理 (DragNgoModoki5.uc.jsも修正)
    // Original function of directSaveLink and setLeafName are from Drag de Go.xpi,
    // and author is Yukichi http://bushwhacker.up.seesaa.net/ .
    //
    // ツールメニューで保存するホルダを指定する
    // 指定されたホルダは about:config  userChrome.save.folders に 「,」区切りで保存
    //
    // 画像をダブルクリックしたときの保存フォルダをIMAGE_DBLCLICKに指定
    // これはabout:config  userChrome.save.folderOnImageDblclickにて変更可能
     -->
      <script type="application/x-javascript" xmlns="http://www.w3.org/1999/xhtml"><![CDATA[
    var saveFolderModoki = {
    //-- config --
      IMAGE_DBLCLICK          : "C:\\Users\\name\\Pictures", // Bilder mit rechten Doppelklick im angegeben Ordner speichern. Dateiauswahlfenster wird dabei nicht geöffnet.
      CONTENTDISPOSITION      : true,       // Inhaltsreihenfolge verwenden[true], nicht verwenden: [false]
      REPLACE_SYSTEM_saveURL  : false,       // Wenn Inhaltsreihenfolge verwenden auf true, dann auch bei URl Speichern Systemstandard verwenden [true], nicht verwenden [false]
      REPLACE_SYSTEM_fileTitle: false,      // Titelattribut als Standarddateinamen verwenden [true], nicht verwenden[false]
    //-- config --
      //Listener-Registrierung
      init: function() {
        this.initPrefs();
        gBrowser.mPanelContainer.addEventListener("dblclick", function(event){saveFolderModoki.onDblClick(event,saveFolderModoki.imagedblclick);}, true);
        this.addPrefListener(saveFolderModoki.buttonPrefListener); // Registrierungsprozess
        if(this.FILENAMEasLINKTEXT && this.FORCELINKTEXT){
          nsContextMenu.prototype.saveImage = saveFolderModoki.saveImageFolder;
        }
      },
      //Listener löschen
      uninit: function() {
        gBrowser.mPanelContainer.removeEventListener("dblclick", function(event){saveFolderModoki.onDblClick(event,saveFolderModoki.imagedblclick);}, true);
        this.removePrefListener(saveFolderModoki.buttonPrefListener); // Registrierungsprozess
      },
      //Version
      getVer: function(){
        const Cc = Components.classes;
        const Ci = Components.interfaces;
        var info = Cc["@mozilla.org/xre/app-info;1"].getService(Ci.nsIXULAppInfo);
        var ver = parseInt(info.version.substr(0,3) * 10,10) / 10;
        return ver;
      },
      //Debuggen
      debug: function(aMsg){
        const Cc = Components.classes;
        const Ci = Components.interfaces;
        Cc["@mozilla.org/consoleservice;1"]
          .getService(Ci.nsIConsoleService)
          .logStringMessage(aMsg);
      },
      getStringBundle: function getStringBundle() {
        // xxx Bug 622423
        if (ContentAreaUtils)
          return ContentAreaUtils.stringBundle;
        else
          return Components.classes['@mozilla.org/intl/stringbundle;1']
                 .getService(Components.interfaces.nsIStringBundleService)
                 .createBundle("chrome://global/locale/contentAreaCommands.properties");
      },
      //Menü
      //Neuen Speicherordner hinzufügen
      addFolderPath: function(){
        var fp = this.getFolderPath();
        var folders = this.getPref('userChrome.save.folders', 'str', '') + ',';
        if (fp){
          if((',' + folders).indexOf(',' + fp.file.path + ',')<0){
            folders = folders + fp.file.path;
            this.setPref('userChrome.save.folders', 'str', folders);
          }
        }
      },
      //Speicherordner editieren
      editFolderPath: function(){
        var folders = this.getPref('userChrome.save.folders', 'str', '');
        folders = window.prompt('Ordner bearbeiten', folders);
        if (folders)
        this.setPref('userChrome.save.folders', 'str', folders);
      },
      //Speicherordner für Dateiauswahl auswählen
      getFolderPath: function(){
        var nsIFilePicker = Components.interfaces.nsIFilePicker;
        var fp = Components.classes["@mozilla.org/filepicker;1"]
                .createInstance(nsIFilePicker);
        fp.init(window, "Select a Folder", nsIFilePicker.modeGetFolder);
        var file = Components.classes["@mozilla.org/file/directory_service;1"]
                             .getService(Components.interfaces.nsIProperties)
                             .get("TmpD", Components.interfaces.nsIFile);
        fp.displayDirectory = file;
        var res = fp.show();
        if (res == nsIFilePicker.returnOK){
          return fp;
        }
        return null;
      },
      //Documentlink Speichern
      saveDocFolder: function(event, afolder){
        var focusedWindow = document.commandDispatcher.focusedWindow;
        if (isContentFrame(focusedWindow)){
          var aDocument = focusedWindow.document;
          if (!aDocument)
            throw "Must have a document when calling saveDocument";
          // We want to use cached data because the document is currently visible.
          var contentDisposition = null;
          try {
            contentDisposition =
              aDocument.defaultView
                       .QueryInterface(Components.interfaces.nsIInterfaceRequestor)
                       .getInterface(Components.interfaces.nsIDOMWindowUtils)
                       .getDocumentMetadata("content-disposition");
          } catch (ex) {
            // Failure to get a content-disposition is ok
          }
          this.internalSave(aDocument.location.href, aDocument, null, contentDisposition,
                       aDocument.contentType, false, null, null,
                       aDocument.referrer ? makeURI(aDocument.referrer) : null,
                       !afolder?false:true, afolder);
        }
      },
      //url Internen speichern und für DragNgoModoki5.uc.js verwenden.
      saveLink: function(url, text, afolder){
        var doc = document.activeElement.ownerDocument;
        contentDisposition.saveURL(url, text, null, true,
                           afolder?true:false, doc.documentURIObject, afolder);
      },
       //Bildadresse speichern
      saveImageURL: function saveImageURL(aURL, aFileName, aFilePickerTitleKey, aShouldBypassCache,
                            aSkipPrompt, aReferrer, aFolder, aDoc){
        const imgICache = Components.interfaces.imgICache;
        const nsISupportsCString = Components.interfaces.nsISupportsCString;
        var contentType = null;
        var contentDisposition = null;
        if (!aShouldBypassCache) {
          try {
             var imageCache = Components.classes["@mozilla.org/image/tools;1"]
                                        .getService(Components.interfaces.imgITools)
                                        .getImgCacheForDocument(aDoc);
             var props =
               imageCache.findEntryProperties(makeURI(aURL, getCharsetforSave(null)));
             if (props) {
               contentType = props.get("type", nsISupportsCString);
               contentDisposition = props.get("content-disposition",
                                              nsISupportsCString);
             }
           } catch (e) {
             // Failure to get type and content-disposition off the image is non-fatal
           }
        }
        if (aFolder){
          this.internalSave(aURL, null, aFileName, contentDisposition, contentType,
                      aShouldBypassCache, aFilePickerTitleKey, null, aReferrer, aSkipPrompt, aFolder);
        } else {
          this.internalSave(aURL, null, aFileName, contentDisposition, contentType,
                      aShouldBypassCache, aFilePickerTitleKey, null, aReferrer, false);
        }
      },
      //Rechten Doppelklick Bild speichern
      onDblClick: function(event, aFolder){
        if(event.button != 2) return;
        if (event.target.tagName.toLowerCase() == "img" && event.target.src){
          event.preventDefault();
          event.stopPropagation();
          document.getElementById("contentAreaContextMenu").hidePopup();
          if(aFolder=='') aFolder =null;
          saveFolderModoki.saveImageFolder(event.target, aFolder);
        }
      },
      //Links, usw. speichern.
      saveLinkFolder: function(target, afolder){
        var url;
        if (target instanceof HTMLAnchorElement ||
            target instanceof HTMLAreaElement){
          url = target.href;
          if(!url) return;
          var text = this.linkText(target, url);
          this.saveLink(url, text, afolder);
        } else if (target instanceof Ci.nsIImageLoadingContent){
          this.saveImageFolder(target, afolder);
        }
      },
      //Speicherung von Bildern
      saveImageFolder: function(target, afolder){
        var url;
        if (target instanceof Ci.nsIImageLoadingContent){
          url = target.src;
        }
        if(!url) return;
        var text = this.linkText(target, url);
        aShouldBypassCache = false;
        if (/^data:/.test(url)){
          text = "index.png";
          // Bypass cache, since it's a data: URL.
          aShouldBypassCache = true;
        }
        this.saveImageURL(url, text, "SaveImageTitle", aShouldBypassCache,
                          afolder?true:false, target.ownerDocument.documentURIObject, afolder, target.ownerDocument);
    },
      //rebuild_userChrome.uc.xulから呼び出される
      directSaveLink: function(dummy, aURL, aDefaultFileName, aDocumentURI, aFolder){
        this.internalSave(aURL, null, aDefaultFileName, null, null, false,
               null, null, aDocumentURI, true, aFolder.path);
      },
      //パス文字列からnsILocalFileを返す この内部およびrebuild_userChrome.uc.xul から呼び出される
      initFileWithPath : function(aPath){
        var file = Components.classes["@mozilla.org/file/local;1"].
                createInstance(Components.interfaces.nsILocalFile);
        file.initWithPath(aPath);
        return file;
      },
      // リンクや画像のリンクからファイル名にする文字列を得る
      // IMAGEFILENAME, LINKFILENAME が "FILENAME" のとき hrefまたはsrc属性のパスを返す
      // 上記以外のとき, リンクテキストまたはtitle,alt属性の文字列を返す
      //
      linkText : function(target, url) {
        var text = gatherTextUnder( target );
        if (!text || !text.match(/\S/)) {
          text = target.getAttribute("title");
          if (!text || !text.match(/\S/)) {
            if (target.hasAttribute("alt")){
              text = target.getAttribute("alt");
              //fx2
              if (!!text && text.match(/Bild-Datei ".+" kann nicht angezeigt werden, weil sie Fehler enthält./)) text = null;
              if (!!text && text.match(/The image ".+" cannot be displayed, because it contains errors./)) text = null;
              //fx3
              if(!!text && text.match(/.*\/(.+)$/)) text = RegExp.$1;
            }
            if (!text || !text.match(/\S/)) {
              if(target.hasAttribute("href")) text = target.href;
              if(target.hasAttribute("src")) text = target.src;
              if(text.match(/.*\/(.+)$/)) text = RegExp.$1;
            }
          }
        }
        return text.replace(/[\\\/:\*\?"<>\|]/g,' '); //"
      },
      /**
       * internalSave: Used when saving a document or URL. This method:
       *  - Determines a local target filename to use (unless parameter
       *    aChosenData is non-null)
       *  - Determines content-type if possible
       *  - Prompts the user to confirm the destination filename and save mode
       *    (content-type affects this)
       *  - Creates a 'Persist' object (which will perform the saving in the
       *    background) and then starts it.
       *
       * @param aURL The String representation of the URL of the document being saved
       * @param aDocument The document to be saved
       * @param aDefaultFileName The caller-provided suggested filename if we don't
       *        find a better one
       * @param aContentDisposition The caller-provided content-disposition header
       *         to use.
       * @param aContentType The caller-provided content-type to use
       * @param aShouldBypassCache If true, the document will always be refetched
       *        from the server
       * @param aFilePickerTitleKey Alternate title for the file picker
       * @param aChosenData If non-null this contains an instance of object AutoChosen
       *        (see below) which holds pre-determined data so that the user does not
       *        need to be prompted for a target filename.
       * @param aReferrer the referrer URI object (not URL string) to use, or null
                if no referrer should be sent.
       * @param aSkipPrompt If true, the file will be saved to the default download folder.
       */
      internalSave: function internalSave(aURL, aDocument, aDefaultFileName, aContentDisposition,
                            aContentType, aShouldBypassCache, aFilePickerTitleKey,
                            aChosenData, aReferrer, aSkipPrompt, aFolderName)
      {
        if (aSkipPrompt == undefined)
          aSkipPrompt = false;
        // Note: aDocument == null when this code is used by save-link-as...
        var saveMode = GetSaveModeForContentType(aContentType);
        var isDocument = aDocument != null && saveMode != SAVEMODE_FILEONLY;
        var saveAsType = kSaveAsType_Complete;
        var file, fileURL;
        // Find the URI object for aURL and the FileName/Extension to use when saving.
        // FileName/Extension will be ignored if aChosenData supplied.
        var fileInfo = new FileInfo(aDefaultFileName);
        if (aChosenData)
          file = aChosenData.file;
        else {
          var charset = null;
          if (aDocument)
            charset = aDocument.characterSet;
          else if (aReferrer)
            charset = aReferrer.originCharset;
          initFileInfo(fileInfo, aURL, charset, aDocument,
                       aContentType, aContentDisposition);
          var fpParams = {
            fpTitleKey: aFilePickerTitleKey,
            isDocument: isDocument,
            fileInfo: fileInfo,
            contentType: aContentType,
            saveMode: saveMode,
            saveAsType: saveAsType,
            file: file,
            fileURL: fileURL
          };
          if (!this.getTargetFile(fpParams, aSkipPrompt, aFolderName))
            // If the method returned false this is because the user cancelled from
            // the save file picker dialog.
            return;
          saveAsType = fpParams.saveAsType;
          saveMode = fpParams.saveMode;
          file = fpParams.file;
          fileURL = fpParams.fileURL;
        }
        if (!fileURL)
          fileURL = makeFileURI(file);
        // XXX We depend on the following holding true in appendFiltersForContentType():
        // If we should save as a complete page, the saveAsType is kSaveAsType_Complete.
        // If we should save as text, the saveAsType is kSaveAsType_Text.
        var useSaveDocument = isDocument &&
                              (((saveMode & SAVEMODE_COMPLETE_DOM) && (saveAsType == kSaveAsType_Complete)) ||
                               ((saveMode & SAVEMODE_COMPLETE_TEXT) && (saveAsType == kSaveAsType_Text)));
        // If we're saving a document, and are saving either in complete mode or
        // as converted text, pass the document to the web browser persist component.
        // If we're just saving the HTML (second option in the list), send only the URI.
        var source = useSaveDocument ? aDocument : fileInfo.uri;
        var persistArgs = {
          source      : source,
          contentType : (!aChosenData && useSaveDocument &&
                         saveAsType == kSaveAsType_Text) ?
                        "text/plain" : null,
          target      : fileURL,
          postData    : isDocument ? getPostData() : null,
          bypassCache : aShouldBypassCache
        };
        var persist = makeWebBrowserPersist();
        // Calculate persist flags.
        const nsIWBP = Components.interfaces.nsIWebBrowserPersist;
        const flags = nsIWBP.PERSIST_FLAGS_REPLACE_EXISTING_FILES;
        if (aShouldBypassCache)
          persist.persistFlags = flags | nsIWBP.PERSIST_FLAGS_BYPASS_CACHE;
        else
          persist.persistFlags = flags | nsIWBP.PERSIST_FLAGS_FROM_CACHE;
        // Leave it to WebBrowserPersist to discover the encoding type (or lack thereof):
        persist.persistFlags |= nsIWBP.PERSIST_FLAGS_AUTODETECT_APPLY_CONVERSION;
        try {
          var isPrivate = PrivateBrowsingUtils.isWindowPrivate(window);
        } catch (e) {
          isPrivate = false;
        }
        // Create download and initiate it (below)
        var tr = Components.classes["@mozilla.org/transfer;1"].createInstance(Components.interfaces.nsITransfer);
        if (useSaveDocument) {
          // Saving a Document, not a URI:
          var filesFolder = null;
          if (persistArgs.contentType != "text/plain") {
            // Create the local directory into which to save associated files.
            filesFolder = file.clone();
            var nameWithoutExtension = getFileBaseName(filesFolder.leafName);
            var filesFolderLeafName = this.getStringBundle()
                                      .formatStringFromName("filesFolder",[nameWithoutExtension], 1);
            filesFolder.leafName = filesFolderLeafName;
          }
          var encodingFlags = 0;
          if (persistArgs.contentType == "text/plain") {
            encodingFlags |= nsIWBP.ENCODE_FLAGS_FORMATTED;
            encodingFlags |= nsIWBP.ENCODE_FLAGS_ABSOLUTE_LINKS;
            encodingFlags |= nsIWBP.ENCODE_FLAGS_NOFRAMES_CONTENT;
          }
          else {
            encodingFlags |= nsIWBP.ENCODE_FLAGS_ENCODE_BASIC_ENTITIES;
          }
          const kWrapColumn = 80;
          tr.init((aChosenData ? aChosenData.uri : fileInfo.uri),
                  persistArgs.target, "", null, null, null, persist, isPrivate);
          try{
            persist.progressListener = new DownloadListener(window, tr);
          } catch(e) {
            persist.progressListener = tr;
          }
          persist.saveDocument(persistArgs.source, persistArgs.target, filesFolder,
                               persistArgs.contentType, encodingFlags, kWrapColumn);
        } else {
          tr.init((aChosenData ? aChosenData.uri : source),
                  persistArgs.target, "", null, null, null, persist, isPrivate);
          try{
            persist.progressListener = new DownloadListener(window, tr);
          } catch(e) {
            persist.progressListener = tr;
          }
          let privacyContext = window.QueryInterface(Ci.nsIInterfaceRequestor)
                                    .getInterface(Ci.nsIWebNavigation)
                                    .QueryInterface(Ci.nsILoadContext);
          if (parseInt(Cc["@mozilla.org/xre/app-info;1"].getService(Ci.nsIXULAppInfo).version) < 36) {
            persist.saveURI((aChosenData ? aChosenData.uri : source),
                            null, 
                            aReferrer,
                            persistArgs.postData, null,
                            persistArgs.target, privacyContext);
          } else {
            persist.saveURI((aChosenData ? aChosenData.uri : source),
                            null, 
                            aReferrer, Ci.nsIHttpChannel.REFERRER_POLICY_NO_REFERRER_WHEN_DOWNGRADE,
                            persistArgs.postData, null,
                            persistArgs.target, privacyContext);
          }
        }
      },
      getTargetFile: function getTargetFile(aFpP, aSkipPrompt, aFolderPath)
      {
        const prefSvcContractID = "@mozilla.org/preferences-service;1";
        const prefSvcIID = Components.interfaces.nsIPrefService;
        var prefs = Components.classes[prefSvcContractID]
                              .getService(prefSvcIID).getBranch("browser.download.");
        const nsILocalFile = Components.interfaces.nsILocalFile;
        // For information on download folder preferences, see
        // mozilla/browser/components/preferences/main.js
        var useDownloadDir = prefs.getBoolPref("useDownloadDir");
        var dir = null;
        // Default to lastDir if useDownloadDir is false, and lastDir
        // is configured and valid. Otherwise, use the user's default
        // downloads directory configured through download prefs.
        var dnldMgr = Components.classes["@mozilla.org/download-manager;1"]
                                .getService(Components.interfaces.nsIDownloadManager);
        //フォルダパスが設定されているなら, dirとしてセットする。
        //aSkipPromptがtrueならファイルピッカを起動しないようにuseDownloadDirをtrueにしておく
        if (aFolderPath){
          try {
            dir = saveFolderModoki.initFileWithPath(aFolderPath);
            if (dir && !dir.exists())
              dir = null;
            if (aSkipPrompt)
              useDownloadDir = true;
          } catch(ex) {}
        }
        //
        if (!dir){
          try {
            var lastDir = prefs.getComplexValue("lastDir", nsILocalFile);
            if ((!aSkipPrompt || !useDownloadDir) && lastDir.exists())
              dir = lastDir;
            else
              dir = dnldMgr.userDownloadsDirectory;
          } catch(ex) {
            dir = dnldMgr.userDownloadsDirectory;
          }
        }
        if (!aSkipPrompt || !useDownloadDir || !dir || (dir && !dir.exists())) {
          if (!dir || (dir && !dir.exists())) {
            // Default to desktop.
            var fileLocator = Components.classes["@mozilla.org/file/directory_service;1"]
                                        .getService(Components.interfaces.nsIProperties);
            dir = fileLocator.get("Desk", nsILocalFile);
          }
          var fp = makeFilePicker();
          var titleKey = aFpP.fpTitleKey || "SaveLinkTitle";
          var bundle = this.getStringBundle();
          fp.init(window, bundle.GetStringFromName(titleKey),
                  Components.interfaces.nsIFilePicker.modeSave);
          fp.defaultExtension = aFpP.fileInfo.fileExt;
          fp.defaultString = getNormalizedLeafName(aFpP.fileInfo.fileName,
                                                   aFpP.fileInfo.fileExt);
          appendFiltersForContentType(fp, aFpP.contentType, aFpP.fileInfo.fileExt,
                                      aFpP.saveMode);
          if (dir)
            fp.displayDirectory = dir;
          if (aFpP.isDocument) {
            try {
              fp.filterIndex = prefs.getIntPref("save_converter_index");
            }
            catch (e) {
            }
          }
          if (fp.show() == Components.interfaces.nsIFilePicker.returnCancel || !fp.file)
            return false;
          var directory = fp.file.parent.QueryInterface(nsILocalFile);
          prefs.setComplexValue("lastDir", nsILocalFile, directory);
          fp.file.leafName = validateFileName(fp.file.leafName);
          aFpP.saveAsType = fp.filterIndex;
          aFpP.file = fp.file;
          aFpP.fileURL = fp.fileURL;
          if (aFpP.isDocument)
            prefs.setIntPref("save_converter_index", aFpP.saveAsType);
        }
        else {
          dir.append(getNormalizedLeafName(aFpP.fileInfo.fileName,
                                           aFpP.fileInfo.fileExt));
          var file = dir;
          // Since we're automatically downloading, we don't get the file picker's
          // logic to check for existing files, so we need to do that here.
          //
          // Note - this code is identical to that in
          //   mozilla/toolkit/mozapps/downloads/src/nsHelperAppDlg.js.in
          // If you are updating this code, update that code too! We can't share code
          // here since that code is called in a js component.
          var collisionCount = 0;
          while (file.exists()) {
            collisionCount++;
            if (collisionCount == 1) {
              // Append "(2)" before the last dot in (or at the end of) the filename
              // special case .ext.gz etc files so we don't wind up with .tar(2).gz
              if (file.leafName.match(/\.[^\.]{1,3}\.(gz|bz2|Z)$/i))
                file.leafName = file.leafName.replace(/\.[^\.]{1,3}\.(gz|bz2|Z)$/i, "(2)$&");
              else
                file.leafName = file.leafName.replace(/(\.[^\.]*)?$/, "(2)$&");
            }
            else {
              // replace the last (n) in the filename with (n+1)
              file.leafName = file.leafName.replace(/^(.*\()\d+\)/, "$1" + (collisionCount+1) + ")");
            }
          }
          aFpP.file = file;
        }
        return true;
      },
      //Kontext-Menü-popup
      popupContextMenu: function(popup){
        //Menüaufbau
        const kXULNS =
               "http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul";
        var folders = this.getPref('userChrome.save.folders', 'str', '').split(',');
        var targets = this.getTargetFromSourceNode(gContextMenu.target);
        var menupopup = document.getElementById('saveFolderModokiContextMenu');
        while(menupopup.lastChild){
          menupopup.removeChild(menupopup.lastChild);
        }
        for(var i=0,len=folders.length;i<len;i++){
          var folder = folders[i];
          if(!folder) continue;
          var menuitem = document.createElementNS(kXULNS,"menuitem");
          menuitem.setAttribute("label", "Seite speichern unter "+ folder);
          menuitem.setAttribute('oncommand',"saveFolderModoki.saveDocFolder(event, this.fp);");
          menuitem.fp = folder;
          menupopup.appendChild(menuitem);
        }
        //Ordner auswählen und speichern
        menuitem = document.createElementNS(kXULNS,"menuitem");
        menuitem.setAttribute("label", 'Seite speichern unter...');
        menuitem.setAttribute('oncommand',"saveFolderModoki.saveDocFolder(event, null);");
        menupopup.appendChild(menuitem);
        if (targets.image || targets.link){
          //セパセータ
          var menusepa = document.createElementNS(kXULNS,"menuseparator");
          menupopup.appendChild(menusepa);
        }
        //Links für Bilder und Popups einfügen
        this.makePopup(menupopup, folders, targets);
      },
      //Bilder und Links für Pop Ups
      makePopup: function(menupopup, folders, targets){
        const kXULNS =
               "http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul";
        if(targets.image){
          //Bild im Ordner speichern
          for(var i=0,len=folders.length;i<len;i++){
            var folder = folders[i];
            if(!folder) continue;
            var menuitem = document.createElementNS(kXULNS,"menuitem");
            menuitem.setAttribute("label", "Grafik speichern unter "+ folder);
            menuitem.setAttribute('oncommand',"saveFolderModoki.saveLinkFolder(this.target, this.fp);");
            menuitem.fp = folder;
            menuitem.target = targets.image;
            menupopup.appendChild(menuitem);
          }
          //Ordner zum Speichern des Bildes wählen
          menuitem = document.createElementNS(kXULNS,"menuitem");
          menuitem.setAttribute("label", 'Grafik speichern unter...');
          menuitem.setAttribute('oncommand',"saveFolderModoki.saveLinkFolder(this.target, null);");
          menuitem.target =targets.image;
          menupopup.appendChild(menuitem);
          if (targets.link){
            //セパセータ
            var menusepa = document.createElementNS(kXULNS,"menuseparator");
            menupopup.appendChild(menusepa);
          }
        }
        if (targets.link){
          //フォルダにリンクを保存
          for(var i=0,len=folders.length;i<len;i++){
            var folder = folders[i];
            if(!folder) continue;
            var menuitem = document.createElementNS(kXULNS,"menuitem");
            menuitem.setAttribute("label", "Link speichern unter "+ folder);
            menuitem.setAttribute('oncommand',"saveFolderModoki.saveLinkFolder(this.target, this.fp);");
            menuitem.fp = folder;
            menuitem.target = targets.link;
            menupopup.appendChild(menuitem);
          }
          //Wählen Sie einen Ordner zum Speichern des Links
          menuitem = document.createElementNS(kXULNS,"menuitem");
          menuitem.setAttribute("label", 'Link speichern unter...');
          menuitem.setAttribute('oncommand',"saveFolderModoki.saveLinkFolder(this.target, null);");
          menuitem.target = targets.link;
          menupopup.appendChild(menuitem);
        }
      },
      //D&Dホットメニュー DragNgoModoki5.uc.js から呼び出される
      showHotMenu: function(x, y){
        const kXULNS =
               "http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul";
        var hotmenu = document.getElementById("saveFolderModokihotmenu");
        if(!hotmenu){
          hotmenu = document.createElementNS(kXULNS,"menupopup");
          hotmenu.setAttribute("id", "saveFolderModokihotmenu");
          this.activeBrowser().appendChild(hotmenu);
        }
        while(hotmenu.lastChild){
          hotmenu.removeChild(hotmenu.lastChild);
        }
        //Menü-Aufbau
        var folders = this.getPref('userChrome.save.folders', 'str', '').split(',');
        //sourcenode
        var target = (('DragNGo' in window) ? DragNGo.sourcenode : (this.sourcenode) ? this.sourcenode : null);
        if (!target) return;
        var targets = this.getTargetFromSourceNode(target);
        this.makePopup(hotmenu, folders, targets);
        document.popupNode = null;
        hotmenu.showPopup(this.activeBrowser(), x, y, "context","bottomleft","topleft");
      },
      //Obere Bild und Link-Knoten erfassen
      getTargetFromSourceNode: function(target){
        var targets = {link:null, image:null};
        if (target &&
            target instanceof Ci.nsIImageLoadingContent &&
            target.src){
          targets.image = target;
        }
        while (target &&
              !(target instanceof HTMLAnchorElement ||
               target instanceof HTMLAreaElement)){
          target = target.parentNode;
        }
        if (!target)
          return targets;
        targets.link = target;
        if (targets.link && !targets.image){
          var images = targets.link.ownerDocument.
                               evaluate('.//*[contains(" img IMG ", concat(" ", local-name(), " "))]',
                                        targets.link,
                                        null,
                                        XPathResult.FIRST_ORDERED_NODE_TYPE,
                                        null);
          if (images && images.singleNodeValue){
            targets.image = images.singleNodeValue;
          }
        }
        return targets;
      },
      //aktuelles Fenster verwenden
      activeBrowser: function() {
        return ('SplitBrowser' in window ? SplitBrowser.activeBrowser : null )
                ||  gBrowser;
      },
      //Lese-Einstellungen
      initPrefs: function() {
        var that = saveFolderModoki;
        that.imagedblclick = that.IMAGE_DBLCLICK;
        var folders = that.getPref('userChrome.save.folders', 'str', '').split(',');
        that.imagedblclick = that.getPref('userChrome.save.folderOnImageDblclick', 'str', that.imagedblclick);
      },
      //pref erhalten
      getPref: function(aPrefString, aPrefType, aDefault){
        var UI = Components.classes["@mozilla.org/intl/scriptableunicodeconverter"].
          createInstance(Components.interfaces.nsIScriptableUnicodeConverter);
        UI.charset = "UTF-8";
        var xpPref = Components.classes['@mozilla.org/preferences-service;1']
                      .getService(Components.interfaces.nsIPrefBranch2);
        try{
          switch (aPrefType){
            case 'complex':
              return xpPref.getComplexValue(aPrefString, Components.interfaces.nsILocalFile); break;
            case 'str':
              return UI.ConvertToUnicode(xpPref.getCharPref(aPrefString).toString()); break;
            case 'int':
              return xpPref.getIntPref(aPrefString); break;
            case 'bool':
            default:
              return xpPref.getBoolPref(aPrefString); break;
          }
        }catch(e){
        }
        return aDefault;
      },
      //pref einsparen
      setPref: function(aPrefString, aPrefType, aValue){
        var UI = Components.classes["@mozilla.org/intl/scriptableunicodeconverter"].
          createInstance(Components.interfaces.nsIScriptableUnicodeConverter);
        UI.charset = "UTF-8";
        var xpPref = Components.classes['@mozilla.org/preferences-service;1']
                      .getService(Components.interfaces.nsIPrefBranch2);
        try{
          switch (aPrefType){
            case 'complex':
              return xpPref.setComplexValue(aPrefString, Components.interfaces.nsILocalFile, aValue); break;
            case 'str':
              return xpPref.setCharPref(aPrefString, UI.ConvertFromUnicode(aValue)); break;
            case 'int':
              aValue = parseInt(aValue);
              return xpPref.setIntPref(aPrefString, aValue);  break;
            case 'bool':
            default:
              return xpPref.setBoolPref(aPrefString, aValue); break;
          }
        }catch(e){
        }
        return null;
      },
      // Starten der Überwachung
      addPrefListener: function(aObserver) {
          try {
              var pbi = Components.classes['@mozilla.org/preferences;1'].getService(Components.interfaces.nsIPrefBranch2);
              pbi.addObserver(aObserver.domain, aObserver, false);
          } catch(e) {}
      },
      // Beenden der Überwachung
      removePrefListener: function(aObserver) {
          try {
              var pbi = Components.classes['@mozilla.org/preferences;1'].getService(Components.interfaces.nsIPrefBranch2);
              pbi.removeObserver(aObserver.domain, aObserver);
          } catch(e) {}
      },
      //Prozess Änderungen
      buttonPrefListener:{
          domain  : 'userChrome.save',
              //"userChrome.save.folders.XXX"という名前の設定が変更された場合全てで処理を行う
          observe : function(aSubject, aTopic, aPrefstring) {
              if (aTopic == 'nsPref:changed') {
                  // Wenn die Einstellungen geändert werden
                  saveFolderModoki.initPrefs();
              }
          }
      }
    }
    saveFolderModoki.init();
    window.addEventListener("unload", function(){ saveFolderModoki.uninit(); }, false);
    //Workarounds bug 299372 (Content-Disposition headers no longer looked at for Save Link As filename,
    //so it uses e.g. "attachment.cgi" in bugzilla instead of the name of the attachment; Save Page As works fine).
    // ****** global
    var contentDisposition = {
      cdisp: new  Array(),
      // ****** if reponse times out
      skip: function(){
        clearTimeout(this.cdisp.timeout);
        this.cdisp.timeout = null;
        saveFolderModoki.internalSave(this.cdisp.url, null, this.cdisp.fileName, null, null, this.cdisp.shouldBypassCache,
                    this.cdisp.filePickerTitleKey, null, this.cdisp.referrer, this.cdisp.skipPrompt, this.cdisp.folder);
      },
      saveURL: function(aURL, aFileName, aFilePickerTitleKey, aShouldBypassCache,
                        aSkipPrompt, aReferrer, aFolder){
        // ****** fill global
        var that = contentDisposition;
        that.cdisp.url = aURL;
        that.cdisp.fileName = aFileName;
        that.cdisp.shouldBypassCache = aShouldBypassCache;
        that.cdisp.filePickerTitleKey = aFilePickerTitleKey;
        that.cdisp.referrer = aReferrer;
        that.cdisp.skipPrompt = aSkipPrompt;
        that.cdisp.folder = aFolder;
        that.cdisp.timeout = null;
        if (!saveFolderModoki.CONTENTDISPOSITION){
          //  content-disposition 使わない
          that.skip();
          return;
        }
        try {
               that.cdisp.timeout = 15000;
            var http_request = new XMLHttpRequest();
            // ******  if reponse recieved and finnished
            http_request.onreadystatechange = function() {
              if (http_request.readyState == 4) {
                // ****** get "Content-disposition" and "Content-Type"
                var disposititon = http_request.getResponseHeader( "Content-disposition");
                var type = http_request.getResponseHeader( "Content-Type");
                if (!disposititon) disposititon = null;
                if (!type) type = null;
                // ****** don't include characterset, better matching
                if ((/text\/html/).test(type)) type = "text/html";
                // ****** default to .htm for links instead of .com, .asp, .php, etc
                if (disposititon == null) {
                        aFileName = aFileName+".htm";
                }
                // ****** alert(aFileName+'******'+disposititon+'******'+type);
                // ****** clear timer
                if (that.cdisp.timeout) {
                  // ****** alert(cdisp.timeout);
                  clearTimeout(that.cdisp.timeout);
                  that.cdisp.timeout = null;
                  saveFolderModoki.internalSave(aURL, null, aFileName, disposititon, type, aShouldBypassCache,
                               aFilePickerTitleKey, null, aReferrer, aSkipPrompt, aFolder);
                }
              }
            };
            // ******  send request, asyncronous true, works in background
            http_request.open("HEAD", aURL, true);
            http_request.send(null);
            // ****** set reponse timeout
            that.cdisp.timeout = setTimeout(function(self){self.skip();}, that.cdisp.timeout, that);
        } catch(e) {
          that.skip();
        }
      }
    }
    if (saveFolderModoki.REPLACE_SYSTEM_saveURL)
      // System Standard SaveURL im Inhaltsdispositions- Verwendung
      window.saveURL = contentDisposition.saveURL;
    //Save as" title as default like in IE
    var savefileTitle = {
      getDefaultFileName:  function(aDefaultFileName, aURI, aDocument, aContentDisposition)
      {
        try {
          fileType = aDocument.contentType;
        }
        catch (e) {
          // nepodarilo se zjistit typ dokumentu
        }
         // 1) look for a filename in the content-disposition header, if any
        if (aContentDisposition) {
          const mhpContractID = "@mozilla.org/network/mime-hdrparam;1";
          const mhpIID = Components.interfaces.nsIMIMEHeaderParam;
          const mhp = Components.classes[mhpContractID].getService(mhpIID);
          var dummy = { value: null };  // Need an out param...
          var charset = getCharsetforSave(aDocument);
          var fileName = null;
          try {
            fileName = mhp.getParameter(aContentDisposition, "filename", charset,
                                        true, dummy);
          }
          catch (e) {
            try {
              fileName = mhp.getParameter(aContentDisposition, "name", charset, true,
                                          dummy);
            }
            catch (e) {
            }
          }
          if (fileName)
            return fileName;
        }
        if (aDocument && fileType == "text/html") {
          var docTitle = validateFileName(aDocument.title).replace(/^\s+|\s+$/g, "");
          if (docTitle) {
            // 3) Use the document title
            return docTitle;
          }
        }
        try {
          var url = aURI.QueryInterface(Components.interfaces.nsIURL);
          if (url.fileName != "") {
            // 2) Use the actual file name, if present
            var textToSubURI = Components.classes["@mozilla.org/intl/texttosuburi;1"]
                                         .getService(Components.interfaces.nsITextToSubURI);
            return validateFileName(textToSubURI.unEscapeURIForUI(url.originCharset || "UTF-8", url.fileName));
          }
        } catch (e) {
          // This is something like a data: and so forth URI... no filename here.
        }
        if (aDefaultFileName)
          // 4) Use the caller-provided name, if any
          return validateFileName(aDefaultFileName);
        // 5) If this is a directory, use the last directory name
        var path = aURI.path.match(/\/([^\/]+)\/$/);
        if (path && path.length > 1)
          return validateFileName(path[1]);
        try {
          if (aURI.host)
            // 6) Use the host.
            return aURI.host;
        } catch (e) {
          // Some files have no information at all, like Javascript generated pages
        }
        try {
          // 7) Use the default file name
          return this.getStringBundle().GetStringFromName("DefaultSaveFileName");
        } catch (e) {
          //in case localized string cannot be found
        }
        // 8) If all else fails, use "index"
        return "index";
      }
    }
    if (saveFolderModoki.REPLACE_SYSTEM_fileTitle)
      // System Methode zum Url speichen, und dabei Standard Dateibezeichnung verwenden
      window.getDefaultFileName = savefileTitle.getDefaultFileName;
      ]]></script>
      <menupopup id="menu_ToolsPopup">
        <menu id="SaveFolderToolsMenu" label="Downloadordner bestimmen" accesskey="D" insertbefore="menu_preferences">
          <menupopup>
    
    
            <menuitem label="Downloadordner suchen"
                      accesskey="s"
                      oncommand="saveFolderModoki.addFolderPath();"/>
            <menuseparator/>
            <menuitem label="Downloadordner editieren"
                      accesskey="t"
                      oncommand="saveFolderModoki.editFolderPath();"/>
          </menupopup>
        </menu>
      </menupopup>
    
    
      <menupopup id="contentAreaContextMenu">
        <menu label="Speichern unter..." accesskey="u">
          <menupopup id="saveFolderModokiContextMenu"
                     onpopupshowing="saveFolderModoki.popupContextMenu(this);event.stopPropagation();"/>
        </menu>
      </menupopup>
    </overlay>
    Alles anzeigen

    ist das noch für Fx+++ hin biegbar?

    gruß uni

  • Script Datum + Uhrzeit neben Menüleiste

    • universum123
    • 15. Dezember 2017 um 15:27

    :-??

    ot

    na ja

    ob das noch lange gut geht

    für so was läuft noch ein geschmierter "aurora/developer beta 55" aufn Rechner bei mir

    so und nu ganz schnell

    ot ende

    uni

  • Script Datum + Uhrzeit neben Menüleiste

    • universum123
    • 15. Dezember 2017 um 15:19
    Zitat von 2002Andreas


    Im Firefox gibt es auch keine Statusbar mehr. :wink:

    <;)

    status.uc.js

    oder reden wir von was anderem

    :-??

  • Lesezeichen-Symbolleiste: Icon+Text umranden.

    • universum123
    • 15. Dezember 2017 um 13:05

    :klasse:

    hat gefunzt

    thx

  • Lesezeichen-Symbolleiste: Icon+Text umranden.

    • universum123
    • 15. Dezember 2017 um 12:57

    :-??

    hmmmm....

    ich habe das nur so übernommen

    wer das mal gepostet hat weiß ich nicht mehr

    mir haben nur "damals" die Rahmen gefallen

    was das andere zu besagen hat :-??

    wie gesagt - es ging mir nur die Rahmen

    was kann ich davon im "code" entsorgen das nur das für die Rahmen über bleibt

    danke uni

  • Lesezeichen-Symbolleiste: Icon+Text umranden.

    • universum123
    • 15. Dezember 2017 um 12:40

    andreas

    kanste dir das mal anschauen ob das für hier passt

    aus meiner userChrome.css

    CSS
    /* Do not remove the @namespace line -- it's required for correct functioning
     * set default namespace to XUL
     */
    @namespace url("http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul");
    
    
    /***** Abschnitt "Nur in der Browser-Oberfläche" *****/
    @-moz-document url-prefix(chrome://browser/content/browser.xul) {
    
    
    /* Rahmen-Stärke, -Farbe, -Radius und Abstände der Buttons */
    /* in der Menue-Leiste */
      #toolbar-menubar toolbarbutton {
        border: 1px solid #999 !important;
        margin: 2px !important;
        border-radius: 4px !important;
      }
    /* in der TAB-Leiste */
      #TabsToolbar toolbarbutton {
        border: 1px solid #ccc !important;
        margin: 2px !important;
        border-radius: 4px !important;
      }
    /* in der Haupt-Leiste */
      #nav-bar toolbarbutton {
        border: 1px solid #ccc !important;
        margin: 2px !important;
        border-radius: 4px !important;
      }
    /* in der Lesezeichen-Leiste */
      #PersonalToolbar toolbarbutton {
        border: 1px solid #ccc !important;
        margin: 2px !important;
        border-radius: 4px !important;
      }
    
    
    /* Lesezeichen Text Schriftfarbe je nach Label-Name verschieden */
      #PersonalToolbar .bookmark-item[label="Name1"] > .toolbarbutton-text,
      #PersonalToolbar .bookmark-item[label="Name2"] > .toolbarbutton-text {
        color:#f77 !important
      }
      #PersonalToolbar .bookmark-item[label="Name3"] > .toolbarbutton-text,
      #PersonalToolbar .bookmark-item[label="Name4"] > .toolbarbutton-text {
        color:#7ff !important
      }
    /* Alle anderen Lesezeichen */
      #PersonalToolbar .bookmark-item {
        color:#fff;
        text-shadow:none !important;
      }
    
    
    } /***** Ende "Nur in der Browser-Oberfläche" *****/
    Alles anzeigen


    danke

    uni

  • Direkt zu "Bibliothek verwalten" per button

    • universum123
    • 13. Dezember 2017 um 13:09

    hi

    ich hoffe das ich dein anliegen richtig verstehe

    geht das nich jetzt schon mit dem "Hamburger" oder dem "Sidebars" Button?

    gruß

  • Videos über XHamster

    • universum123
    • 11. Dezember 2017 um 15:07

    hi

    Zitat

    Es baut sich im Videofenster nur ein schwarzer Bildschirm auf.

    uMatrix oder NoScript am laufen?

    gruß

  • Video DownloadHelper

    • universum123
    • 3. Dezember 2017 um 11:57

    der VLC kann fast alle Video Files ohne "Codecs" abspielen

    beim VDH kannste doch aussuchen in was du "Downloaden" willst

    [attachment=1]VDH auflösung HD.png[/attachment]

    [attachment=0]VLC Einstell. Zuordnungen.png[/attachment]

    :-??

    Bilder

    • VLC Einstell. Zuordnungen.png
      • 200,64 kB
      • 855 × 591
    • VDH auflösung HD.png
      • 671,47 kB
      • 1.920 × 1.080
  • Video DownloadHelper

    • universum123
    • 3. Dezember 2017 um 11:14

    :-???

    warum nicht in *.mp4? oder*.mkv

    ist doch allgemeiner "Standard"

    *.avi ist doch out <;)

    gruß

  • Bilder (jpg) sofort in den Download-Ordner

    • universum123
    • 1. Dezember 2017 um 19:10

    :-??

    Save Image In Folder

    Zitat

    Do you like saving many different pictures as I do?
    Did you use this extension for years: Save Image In Folder, and feared that it will not work on new versions of Firefox?
    Now you can use this new extension and enjoy the piece of mind.

    You can define as many folders as you like and save there pictures you like in one click. But all the folders must reside in your main Downloads folder. This is a limitation of WebExtensions API.

  • Restart Firefox Button movable ?

    • universum123
    • 26. November 2017 um 15:07

    [Blockierte Grafik: http://www.smilies.4-user.de/include/Schilder/smilie_m_010.gif]


    hat nich "EffPeh" mal eine kleine Zusammenstellung gemacht wo was hin muss!?

    "firefox-anpassungen.zip"

    find nu grade nich

    gruß


    [attachment=0]firefox-anpassungen-mit-beispiel.zip[/attachment]

    Dateien

    firefox-anpassungen-mit-beispiel.zip 80,13 kB – 191 Downloads
  • Theme wird bei Firefox Quantum nicht übernommen

    • universum123
    • 26. November 2017 um 09:21

    moin

    nur kurz dazu

    - welches Theme

    - bei Versionen ab Fx 57 gibt es keine "vollständigen Themen" mehr ( imho )

    gruß

  • Restart Firefox Button movable ?

    • universum123
    • 26. November 2017 um 09:13

    [Blockierte Grafik: http://www.smilies.4-user.de/include/Schilder/smilie_m_006.gif]

    :-??

    so heist es bei mir und funzt (Fx Profilordner --> chrome)

    RestartFirefoxButton_Movable.uc.js

    Code
    //		RestartFirefoxButtonM.uc.js
    //		v. 0.3
    
    
    (function() {
    
    
       if (location != 'chrome://browser/content/browser.xul') return;
    
    	try {
    		CustomizableUI.createWidget({
    			id: 'restart-button',
    			type: 'custom',
    			defaultArea: CustomizableUI.AREA_NAVBAR,
    			onBuild: function(aDocument) {			
    				var toolbaritem = aDocument.createElementNS('http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul', 'toolbarbutton');
    				var props = {
    					id: 'restart-button',
    					class: 'toolbarbutton-1 chromeclass-toolbar-additional',
    					label: 'Neustart',
    					tooltiptext: 'Neustart (mit Rechts- und Mittelklick wird userChrome.js-Cache geleert)',
    					style: 'list-style-image: url(%2F9hAAAACXBIWXMAAAsTAAALEwEAmpwYAAAKT2lDQ1BQaG90b3Nob3AgSUNDIHByb2ZpbGUAAHjanVNnVFPpFj333vRCS4iAlEtvUhUIIFJCi4AUkSYqIQkQSoghodkVUcERRUUEG8igiAOOjoCMFVEsDIoK2AfkIaKOg6OIisr74Xuja9a89%2BbN%2FrXXPues852zzwfACAyWSDNRNYAMqUIeEeCDx8TG4eQuQIEKJHAAEAizZCFz%2FSMBAPh%2BPDwrIsAHvgABeNMLCADATZvAMByH%2Fw%2FqQplcAYCEAcB0kThLCIAUAEB6jkKmAEBGAYCdmCZTAKAEAGDLY2LjAFAtAGAnf%2BbTAICd%2BJl7AQBblCEVAaCRACATZYhEAGg7AKzPVopFAFgwABRmS8Q5ANgtADBJV2ZIALC3AMDOEAuyAAgMADBRiIUpAAR7AGDIIyN4AISZABRG8lc88SuuEOcqAAB4mbI8uSQ5RYFbCC1xB1dXLh4ozkkXKxQ2YQJhmkAuwnmZGTKBNA%2Fg88wAAKCRFRHgg%2FP9eM4Ors7ONo62Dl8t6r8G%2FyJiYuP%2B5c%2BrcEAAAOF0ftH%2BLC%2BzGoA7BoBt%2FqIl7gRoXgugdfeLZrIPQLUAoOnaV%2FNw%2BH48PEWhkLnZ2eXk5NhKxEJbYcpXff5nwl%2FAV%2F1s%2BX48%2FPf14L7iJIEyXYFHBPjgwsz0TKUcz5IJhGLc5o9H%2FLcL%2F%2Fwd0yLESWK5WCoU41EScY5EmozzMqUiiUKSKcUl0v9k4t8s%2BwM%2B3zUAsGo%2BAXuRLahdYwP2SycQWHTA4vcAAPK7b8HUKAgDgGiD4c93%2F%2B8%2F%2FUegJQCAZkmScQAAXkQkLlTKsz%2FHCAAARKCBKrBBG%2FTBGCzABhzBBdzBC%2FxgNoRCJMTCQhBCCmSAHHJgKayCQiiGzbAdKmAv1EAdNMBRaIaTcA4uwlW4Dj1wD%2FphCJ7BKLyBCQRByAgTYSHaiAFiilgjjggXmYX4IcFIBBKLJCDJiBRRIkuRNUgxUopUIFVIHfI9cgI5h1xGupE7yAAygvyGvEcxlIGyUT3UDLVDuag3GoRGogvQZHQxmo8WoJvQcrQaPYw2oefQq2gP2o8%2BQ8cwwOgYBzPEbDAuxsNCsTgsCZNjy7EirAyrxhqwVqwDu4n1Y8%2BxdwQSgUXACTYEd0IgYR5BSFhMWE7YSKggHCQ0EdoJNwkDhFHCJyKTqEu0JroR%2BcQYYjIxh1hILCPWEo8TLxB7iEPENyQSiUMyJ7mQAkmxpFTSEtJG0m5SI%2BksqZs0SBojk8naZGuyBzmULCAryIXkneTD5DPkG%2BQh8lsKnWJAcaT4U%2BIoUspqShnlEOU05QZlmDJBVaOaUt2ooVQRNY9aQq2htlKvUYeoEzR1mjnNgxZJS6WtopXTGmgXaPdpr%2Bh0uhHdlR5Ol9BX0svpR%2BiX6AP0dwwNhhWDx4hnKBmbGAcYZxl3GK%2BYTKYZ04sZx1QwNzHrmOeZD5lvVVgqtip8FZHKCpVKlSaVGyovVKmqpqreqgtV81XLVI%2BpXlN9rkZVM1PjqQnUlqtVqp1Q61MbU2epO6iHqmeob1Q%2FpH5Z%2FYkGWcNMw09DpFGgsV%2FjvMYgC2MZs3gsIWsNq4Z1gTXEJrHN2Xx2KruY%2FR27iz2qqaE5QzNKM1ezUvOUZj8H45hx%2BJx0TgnnKKeX836K3hTvKeIpG6Y0TLkxZVxrqpaXllirSKtRq0frvTau7aedpr1Fu1n7gQ5Bx0onXCdHZ4%2FOBZ3nU9lT3acKpxZNPTr1ri6qa6UbobtEd79up%2B6Ynr5egJ5Mb6feeb3n%2Bhx9L%2F1U%2FW36p%2FVHDFgGswwkBtsMzhg8xTVxbzwdL8fb8VFDXcNAQ6VhlWGX4YSRudE8o9VGjUYPjGnGXOMk423GbcajJgYmISZLTepN7ppSTbmmKaY7TDtMx83MzaLN1pk1mz0x1zLnm%2Beb15vft2BaeFostqi2uGVJsuRaplnutrxuhVo5WaVYVVpds0atna0l1rutu6cRp7lOk06rntZnw7Dxtsm2qbcZsOXYBtuutm22fWFnYhdnt8Wuw%2B6TvZN9un2N%2FT0HDYfZDqsdWh1%2Bc7RyFDpWOt6azpzuP33F9JbpL2dYzxDP2DPjthPLKcRpnVOb00dnF2e5c4PziIuJS4LLLpc%2BLpsbxt3IveRKdPVxXeF60vWdm7Obwu2o26%2FuNu5p7ofcn8w0nymeWTNz0MPIQ%2BBR5dE%2FC5%2BVMGvfrH5PQ0%2BBZ7XnIy9jL5FXrdewt6V3qvdh7xc%2B9j5yn%2BM%2B4zw33jLeWV%2FMN8C3yLfLT8Nvnl%2BF30N%2FI%2F9k%2F3r%2F0QCngCUBZwOJgUGBWwL7%2BHp8Ib%2BOPzrbZfay2e1BjKC5QRVBj4KtguXBrSFoyOyQrSH355jOkc5pDoVQfujW0Adh5mGLw34MJ4WHhVeGP45wiFga0TGXNXfR3ENz30T6RJZE3ptnMU85ry1KNSo%2Bqi5qPNo3ujS6P8YuZlnM1VidWElsSxw5LiquNm5svt%2F87fOH4p3iC%2BN7F5gvyF1weaHOwvSFpxapLhIsOpZATIhOOJTwQRAqqBaMJfITdyWOCnnCHcJnIi%2FRNtGI2ENcKh5O8kgqTXqS7JG8NXkkxTOlLOW5hCepkLxMDUzdmzqeFpp2IG0yPTq9MYOSkZBxQqohTZO2Z%2Bpn5mZ2y6xlhbL%2BxW6Lty8elQfJa7OQrAVZLQq2QqboVFoo1yoHsmdlV2a%2FzYnKOZarnivN7cyzytuQN5zvn%2F%2FtEsIS4ZK2pYZLVy0dWOa9rGo5sjxxedsK4xUFK4ZWBqw8uIq2Km3VT6vtV5eufr0mek1rgV7ByoLBtQFr6wtVCuWFfevc1%2B1dT1gvWd%2B1YfqGnRs%2BFYmKrhTbF5cVf9go3HjlG4dvyr%2BZ3JS0qavEuWTPZtJm6ebeLZ5bDpaql%2BaXDm4N2dq0Dd9WtO319kXbL5fNKNu7g7ZDuaO%2FPLi8ZafJzs07P1SkVPRU%2BlQ27tLdtWHX%2BG7R7ht7vPY07NXbW7z3%2FT7JvttVAVVN1WbVZftJ%2B7P3P66Jqun4lvttXa1ObXHtxwPSA%2F0HIw6217nU1R3SPVRSj9Yr60cOxx%2B%2B%2Fp3vdy0NNg1VjZzG4iNwRHnk6fcJ3%2FceDTradox7rOEH0x92HWcdL2pCmvKaRptTmvtbYlu6T8w%2B0dbq3nr8R9sfD5w0PFl5SvNUyWna6YLTk2fyz4ydlZ19fi753GDborZ752PO32oPb%2B%2B6EHTh0kX%2Fi%2Bc7vDvOXPK4dPKy2%2BUTV7hXmq86X23qdOo8%2FpPTT8e7nLuarrlca7nuer21e2b36RueN87d9L158Rb%2F1tWeOT3dvfN6b%2FfF9%2FXfFt1%2Bcif9zsu72Xcn7q28T7xf9EDtQdlD3YfVP1v%2B3Njv3H9qwHeg89HcR%2FcGhYPP%2FpH1jw9DBY%2BZj8uGDYbrnjg%2BOTniP3L96fynQ89kzyaeF%2F6i%2FsuuFxYvfvjV69fO0ZjRoZfyl5O%2FbXyl%2FerA6xmv28bCxh6%2ByXgzMV70VvvtwXfcdx3vo98PT%2BR8IH8o%2F2j5sfVT0Kf7kxmTk%2F8EA5jz%2FGMzLdsAAAAEZ0FNQQAAsY58%2B1GTAAAAIGNIUk0AAHolAACAgwAA%2Bf8AAIDpAAB1MAAA6mAAADqYAAAXb5JfxUYAAAN8SURBVHjaVJFNTBxlAIafb2Z29gd2l4VdYCkokAUt1AJplQRTrVqjUWMPPWHSCzb21IOn9qIHY2xMahoTTb00NmkUm5qAjdpUI61VaCxCpCVYixt%2ByvKzCwu7LDs7zMw3HmhM%2Bt6fJ0%2FyCp69wiOzZBCPcqSmIXg0HPHuC4R8nkLWyOXyYiIzfuVHzMIA%2BZsLtH18EApntUdhpzUSD5577nDLi%2FGWKjx%2BHVfR8HpFwNwsxTMzza%2BOXJ1%2B58Ev2sVEV%2ByEawXqxf8FllNWEQ9ePXzsqQOecIDU8jampSAVD76Al2BIIx4Dv2Nz7%2FYq%2B5%2BP8sNXE6WdAhdQlOM9rzUdaGiN8M9UjnKvQjzuA0UjV3AxDIcHywqRoEbXoVrKgyBtKXYEUvprmiN9oaoyvr9wl62NHJbtJeDzOo17YmprVzWOppLO2RRNwf1FSOzSUAXsCIR4QdP13UPfjhUde2mjuBXUjcXNEabOnJmq7Y4Nd7z1fu%2BJ%2FR2Jpgrm0jauAI8GlnSlBi4I0bO6sLBWHc9esxRdmjOZf5n%2B5CLWzCzOvsbKupBZ1xgmElUoC%2BgoKtRGQfNomoaND8P8XS%2Bby1olO7O6GHTl1DejGDOrNB%2BvpO7I%2Ba31%2FDP9Z28YUmqoqhCKcG2EYD6ZMUTojZ8WHmsqD%2BI6wnWFajugCkuuZaV%2FZS47wp99R7E3LbxPV6rtr7dV1pmyuBWs3hr7dZ380LC2tzseffvUHm86C1JC2A%2FrGcn509cn%2BPvTk9ibc1R06qL91Ms1CadF000ll9rVS2VykLzVr0lHOgtpuJ9yUFyXxqhKZjbH2nJRI9IZwyw2kXjvXV%2FIOWgaBcc2a%2BtjdVXR1J3iBDx8QUpQUJAuJJclseogxz441H5vrPO72cm0VSyVPJq27ZaHm8ST3Y0M9d9Kkr19A1A1x4VIObTGBfNrsJ5XmE9b6KqgvrOGhr1Vns2sgeNIkXiigvHf1liZuHWZYjINSEXRVLewZjN6bYmYbvN4rcDvVzFKLnOpErMLBpvbklClznyyyPDA6DjTX3wJWICr%2Bnb3ffjXSGpl5Nxnn88uh2ORUCBaHfVQU%2BsjVuGhKqJT5lFYShr8fGH4j42bH53EnJ4EtgEEPQOTzHx9mqXLl9AT9TS82RvreOmVcMTXVh4JhIr5kp3LFu6u3Lk%2ByMylQazU3ENYAvw3AFUTimFqj5i7AAAAAElFTkSuQmCC)',
    					onclick: 'if (event.button == 1 || event.button == 2) { \
    									event.preventDefault(); \
    									Cc["@mozilla.org/xre/app-info;1"].getService(Ci.nsIXULRuntime). \
    										invalidateCachesOnRestart(); \
    								 }; \
    								 BrowserUtils.restartApplication();'
    				};				
    				for (var p in props)
    					toolbaritem.setAttribute(p, props[p]);				
    				return toolbaritem;
    			}		
    		});
    	} catch(e) { };		
    
    })();
    Alles anzeigen

    gruß

  • Sechs Firefox-Prozesse im Task-Manager?! Wieso?

    • universum123
    • 25. November 2017 um 12:02

    ??

    wie viele tabs hattest du zu derzeit offen!?

    gruß

  • FF 57 Mehrzeilige Tab-Leiste

    • universum123
    • 24. November 2017 um 15:40

    jep Zwischenraum müsste kleiner werden

    [attachment=0]Mehrzeilige Tab-Leiste zu Groß das ganze.png[/attachment]

    Bilder

    • Mehrzeilige Tab-Leiste zu Groß das ganze.png
      • 343,32 kB
      • 1.920 × 1.080
  • Warum ist ein bestimmter Downloadort festgelegt?

    • universum123
    • 24. November 2017 um 08:40

    moin

    Mozilla und Restriktionen (WebExt)

    vielleicht findet ja einer einen Trick um das zu umgehen

    dient nur zur Info ... (ohne Gewähr)

    Zitat

    Sie können beliebig viele Ordner definieren und mit einem Klick Bilder speichern, die Ihnen gefallen. Aber alle Ordner müssen sich in Ihrem Hauptordner Downloads befinden. Dies ist eine Einschränkung der WebExtensions-API.

    es geht nur um "Speicherortfestlegung" in Add-ons


    gruß

  • Downloadhelper seit Firefox 57.0

    • universum123
    • 24. November 2017 um 08:30

    [Blockierte Grafik: http://www.smilies.4-user.de/include/Schilder/smilie_m_006.gif]

    :-?? wozu "Zusatzsoftware" und "Lizenz"

    wofür bitte?

    Zitat

    ...
    flv|ram|mpg|mpeg|avi|rm|wmv|mov|asf|mp3|rar|movie|divx|rbs|mp4|mpeg4
    ...


    https://addons.mozilla.org/en-US/firefox/…r/versions/beta

    :-??

  • Downloadhelper seit Firefox 57.0

    • universum123
    • 22. November 2017 um 15:41

    :-??

    ? Bild richtig betrachtet?

    Einstellung kann man(n) nicht machen (jedenfalls nur minimal)

    VDH zeigt alle Auflösungen an die Runter geladen werden können

    https://addons.mozilla.org/en-US/firefox/…r/versions/beta

  • Downloadhelper seit Firefox 57.0

    • universum123
    • 22. November 2017 um 11:57

    :-??

    [attachment=0]VDH auflösung HD.png[/attachment]

    Bilder

    • VDH auflösung HD.png
      • 671,47 kB
      • 1.920 × 1.080

Unterstütze uns!

Jährlich (2025)

92,9 %

92,9% (604,17 von 650 EUR)

Jetzt spenden
  1. Kontakt
  2. Datenschutz
  3. Impressum
Community-Software: WoltLab Suite™
Mastodon