Verified Commit 01f753ff authored by Raphael Fetzer's avatar Raphael Fetzer 🕵🏻
Browse files

Version 0.2 - the whole enchilada

parent b35c8bb1
/*!
* Bootstrap Colorpicker v2.5.2
* https://itsjavi.com/bootstrap-colorpicker/
*
* Originally written by (c) 2012 Stefan Petre
* Licensed under the Apache License v2.0
* http://www.apache.org/licenses/LICENSE-2.0.txt
*
*/.colorpicker-saturation{width:100px;height:100px;background-image:url();cursor:crosshair;float:left}.colorpicker-saturation i{display:block;height:5px;width:5px;border:1px solid #000;-webkit-border-radius:5px;-moz-border-radius:5px;border-radius:5px;position:absolute;top:0;left:0;margin:-4px 0 0 -4px}.colorpicker-saturation i b{display:block;height:5px;width:5px;border:1px solid #fff;-webkit-border-radius:5px;-moz-border-radius:5px;border-radius:5px}.colorpicker-alpha,.colorpicker-hue{width:15px;height:100px;float:left;cursor:row-resize;margin-left:4px;margin-bottom:4px}.colorpicker-alpha i,.colorpicker-hue i{display:block;height:1px;background:#000;border-top:1px solid #fff;position:absolute;top:0;left:0;width:100%;margin-top:-1px}.colorpicker-hue{background-image:url()}.colorpicker-alpha{background-image:url();display:none}.colorpicker-alpha,.colorpicker-hue,.colorpicker-saturation{background-size:contain}.colorpicker{padding:4px;min-width:130px;margin-top:1px;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;z-index:2500}.colorpicker:after,.colorpicker:before{display:table;content:"";line-height:0}.colorpicker:after{clear:both}.colorpicker:before{content:'';display:inline-block;border-left:7px solid transparent;border-right:7px solid transparent;border-bottom:7px solid #ccc;border-bottom-color:rgba(0,0,0,.2);position:absolute;top:-7px;left:6px}.colorpicker:after{content:'';display:inline-block;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:6px solid #fff;position:absolute;top:-6px;left:7px}.colorpicker div{position:relative}.colorpicker.colorpicker-with-alpha{min-width:140px}.colorpicker.colorpicker-with-alpha .colorpicker-alpha{display:block}.colorpicker-color{height:10px;margin-top:5px;clear:both;background-image:url();background-position:0 100%}.colorpicker-color div{height:10px}.colorpicker-selectors{display:none;height:10px;margin-top:5px;clear:both}.colorpicker-selectors i{cursor:pointer;float:left;height:10px;width:10px}.colorpicker-selectors i+i{margin-left:3px}.colorpicker-element .add-on i,.colorpicker-element .input-group-addon i{display:inline-block;cursor:pointer;height:16px;vertical-align:text-top;width:16px}.colorpicker.colorpicker-inline{position:relative;display:inline-block;float:none;z-index:auto}.colorpicker.colorpicker-horizontal{width:110px;min-width:110px;height:auto}.colorpicker.colorpicker-horizontal .colorpicker-saturation{margin-bottom:4px}.colorpicker.colorpicker-horizontal .colorpicker-color{width:100px}.colorpicker.colorpicker-horizontal .colorpicker-alpha,.colorpicker.colorpicker-horizontal .colorpicker-hue{width:100px;height:15px;float:left;cursor:col-resize;margin-left:0;margin-bottom:4px}.colorpicker.colorpicker-horizontal .colorpicker-alpha i,.colorpicker.colorpicker-horizontal .colorpicker-hue i{display:block;height:15px;background:#fff;position:absolute;top:0;left:0;width:1px;border:none;margin-top:0}.colorpicker.colorpicker-horizontal .colorpicker-hue{background-image:url()}.colorpicker.colorpicker-horizontal .colorpicker-alpha{background-image:url()}.colorpicker-right:before{left:auto;right:6px}.colorpicker-right:after{left:auto;right:7px}.colorpicker-no-arrow:before{border-right:0;border-left:0}.colorpicker-no-arrow:after{border-right:0;border-left:0}.colorpicker-alpha.colorpicker-visible,.colorpicker-hue.colorpicker-visible,.colorpicker-saturation.colorpicker-visible,.colorpicker-selectors.colorpicker-visible,.colorpicker.colorpicker-visible{display:block}.colorpicker-alpha.colorpicker-hidden,.colorpicker-hue.colorpicker-hidden,.colorpicker-saturation.colorpicker-hidden,.colorpicker-selectors.colorpicker-hidden,.colorpicker.colorpicker-hidden{display:none}.colorpicker-inline.colorpicker-visible{display:inline-block}
/*# sourceMappingURL=bootstrap-colorpicker.min.css.map */
\ No newline at end of file
{"version":3,"sources":["src/less/colorpicker.less"],"names":[],"mappings":";;;;;;;;AAoBA,wBACE,MAAA,MACA,OAAA,MAXA,iBAAsB,g7KAatB,OAAA,UACA,MAAA,KACA,0BACE,QAAA,MACA,OAAA,IACA,MAAA,IACA,OAAA,IAAA,MAAA,KAfF,sBAAA,IACA,mBAAA,IACA,cAAA,IAeE,SAAA,SACA,IAAA,EACA,KAAA,EACA,OAAA,KAAA,EAAA,EAAA,KACA,4BACE,QAAA,MACA,OAAA,IACA,MAAA,IACA,OAAA,IAAA,MAAA,KAzBJ,sBAAA,IACA,mBAAA,IACA,cAAA,IA8BF,mBADA,iBAEE,MAAA,KACA,OAAA,MACA,MAAA,KACA,OAAA,WACA,YAAA,IACA,cAAA,IAIiB,qBADF,mBAEf,QAAA,MACA,OAAA,IACA,WAAA,KACA,WAAA,IAAA,MAAA,KACA,SAAA,SACA,IAAA,EACA,KAAA,EACA,MAAA,KACA,WAAA,KAGF,iBA1DE,iBAAsB,4rBA8DxB,mBA9DE,iBAAsB,wqBAgEtB,QAAA,KAKF,mBADA,iBADA,wBAGE,gBAAA,QAGF,aACE,QAAA,IACA,UAAA,MACA,WAAA,IAxEA,sBAAA,IACA,mBAAA,IACA,cAAA,IAwEA,QAAA,KAIU,mBADA,oBAEV,QAAA,MACA,QAAA,GACA,YAAA,EAGU,mBACV,MAAA,KAGU,oBACV,QAAA,GACA,QAAA,aACA,YAAA,IAAA,MAAA,YACA,aAAA,IAAA,MAAA,YACA,cAAA,IAAA,MAAA,KACA,oBAAA,eACA,SAAA,SACA,IAAA,KACA,KAAA,IAGU,mBACV,QAAA,GACA,QAAA,aACA,YAAA,IAAA,MAAA,YACA,aAAA,IAAA,MAAA,YACA,cAAA,IAAA,MAAA,KACA,SAAA,SACA,IAAA,KACA,KAAA,IAGW,iBACX,SAAA,SAGU,oCACV,UAAA,MAGkC,uDAClC,QAAA,MAGF,mBACE,OAAA,KACA,WAAA,IACA,MAAA,KAlIA,iBAAsB,wqBAoItB,oBAAA,EAAA,KAGiB,uBACjB,OAAA,KAGF,uBACE,QAAA,KACA,OAAA,KACA,WAAA,IACA,MAAA,KAGqB,yBACrB,OAAA,QACA,MAAA,KACA,OAAA,KACA,MAAA,KAGuB,2BACvB,YAAA,IAI2B,+BADW,0CAEtC,QAAA,aACA,OAAA,QACA,OAAA,KACA,eAAA,SACA,MAAA,KAGU,gCACV,SAAA,SACA,QAAA,aACA,MAAA,KACA,QAAA,KAGU,oCACV,MAAA,MACA,UAAA,MACA,OAAA,KAGkC,4DAClC,cAAA,IAGkC,uDAClC,MAAA,MAIkC,uDADA,qDAElC,MAAA,MACA,OAAA,KACA,MAAA,KACA,OAAA,WACA,YAAA,EACA,cAAA,IAIqD,yDADF,uDAEnD,QAAA,MACA,OAAA,KACA,WAAA,KACA,SAAA,SACA,IAAA,EACA,KAAA,EACA,MAAA,IACA,OAAA,KACA,WAAA,EAGkC,qDAlNlC,iBAAsB,4pBAsNY,uDAtNlC,iBAAsB,owBA0NN,0BAChB,KAAA,KACA,MAAA,IAGgB,yBAChB,KAAA,KACA,MAAA,IAGmB,6BACnB,aAAA,EACA,YAAA,EAGmB,4BACnB,aAAA,EACA,YAAA,EAQC,uCAAA,qCAAA,4CAAA,2CAAA,iCACC,QAAA,MASD,sCAAA,oCAAA,2CAAA,0CAAA,gCACC,QAAA,KAIe,wCACjB,QAAA"}
\ No newline at end of file
This diff is collapsed.
/* nunito-regular - latin */
@font-face {
font-family: 'Nunito';
font-style: normal;
font-weight: 400;
src: url('../fonts/nunito-v9-latin-regular.eot');
/* IE9 Compat Modes */
src: local('Nunito Regular'), local('Nunito-Regular'), url('../fonts/nunito-v9-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
url('../fonts/nunito-v9-latin-regular.woff2') format('woff2'), /* Super Modern Browsers */
url('../fonts/nunito-v9-latin-regular.woff') format('woff'), /* Modern Browsers */
url('../fonts/nunito-v9-latin-regular.ttf') format('truetype'), /* Safari, Android, iOS */
url('../fonts/nunito-v9-latin-regular.svg#Nunito') format('svg');
/* Legacy iOS */
}
/* nunito-800 - latin */
@font-face {
font-family: 'Nunito';
font-style: normal;
font-weight: 800;
src: url('../fonts/nunito-v9-latin-800.eot');
/* IE9 Compat Modes */
src: local('Nunito ExtraBold'), local('Nunito-ExtraBold'), url('../fonts/nunito-v9-latin-800.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
url('../fonts/nunito-v9-latin-800.woff2') format('woff2'), /* Super Modern Browsers */
url('../fonts/nunito-v9-latin-800.woff') format('woff'), /* Modern Browsers */
url('../fonts/nunito-v9-latin-800.ttf') format('truetype'), /* Safari, Android, iOS */
url('../fonts/nunito-v9-latin-800.svg#Nunito') format('svg');
/* Legacy iOS */
}
body,
h2,
h5 {
font-family: 'Nunito', serif;
}
#main {
padding: 0;
box-shadow: 0 0 10px #0002;
border-radius: 6px;
background-color: white;
margin-top: 1em;
margin-bottom: 2em;
min-height: 500px;
}
a {
color: #208692;
}
.btn {
background-color: #208692;
color: white;
}
.btn:hover {
background-color: #409da5;
color: white;
}
.btn:active {
background-color: #208592;
}
.backgroundimage {
background-color: #268693;
background-image: url(../media/background.jpg);
margin-bottom: 2em;
min-height: 700px;
padding-top: 2em;
}
#footer {
min-height: 100%; /* Fallback for browsers do NOT support vh unit */
min-height: 10vh; /* These two lines are counted as one :-) */
display: flex;
align-items: center;
padding-bottom: 1em;
}
#footer p {
margin-bottom: 0.5em;
}
@media(max-width:767px) {
#main {
border-radius: 0;
}
.col-lg-10 {
padding: 0;
}
#footer {
display: block;
}
}
#preview h1, #preview h2 {
color: #4a8591;
text-align: left;
}
#colorcontraststatus {
padding: 4px 6px;
font-weight: bold;
}
.colorpicker-alpha {
display: none !important;
}
.colorpicker-hue {
width: 30px;
}
video {
width: 100%;
height: auto;
}
@media (min-width:768px) {
.container .jumbotron, .container-fluid .jumbotron {
margin-left: 200px;
}
}
This diff is collapsed.
This diff is collapsed.
<!doctype html>
<html lang="de">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no">
<title>Themebot</title>
<script src="js/FileSaver.js"></script>
<script src="js/jquery-3.2.1.min.js"></script>
<script src="js/bootstrap-colorpicker.min.js"></script>
<script src="js/bootstrap-3.3.7.min.js"></script>
<link href="css/bootstrap.3.3.7.min.css" rel="stylesheet">
<link href="css/bootstrap-colorpicker.min.css" rel="stylesheet">
<link href="css/themebot.css" rel="stylesheet">
</head>
<body>
<div class="container-fluid">
<div class="row backgroundimage">
<div class="col-lg-10 col-lg-offset-1">
<img src="media/robot-face.svg" style="width: 170px; float: left; margin: 30px 30px 20px 10px;">
<div class="jumbotron" style="background-color: white;">
<p>Hallo! Ich bin der <strong>Themebot</strong> und erstelle fertige Themes für <a href="https://www.openolat.com">OpenOlat</a>-Kurse. Unten können dafür Schriftarten und -farbe angepasst und auf Wunsch ein zweispaltiges Kacheldesign eingestellt werden. Viel Spaß damit! <i>*biep*</i></p>
<div>
<a data-toggle="collapse" href="#anleitung" role="button" aria-expanded="false" aria-controls="collapse">Installationshinweise anzeigen</a>
</div>
<div class="collapse" id="anleitung">
<ol>
<li>CSS-Datei (theme.css) herunterladen</li>
<li>Im Ablageordner des OLAT-Kurses einen Ordner mit dem Namen courseCSS erstellen.</li>
<li>Erstellte Datei (theme.css) in Ordner courseCSS speichern</li>
<li>Unter Einstellungen/„Layout“ die CSS-Datei einstellen.</li>
</ol>
<video width="320" height="240" controls>
<source src="media/olatdesigncss.mp4" type="video/mp4">
</video>
</div>
</div>
<div id="main">
<form method="post" enctype="multipart/form-data" onsubmit="return BuildCSS();" class="form-horizontal" style="padding: 2em;">
<fieldset>
<!-- Form Name -->
<legend>Theme-Einstellungen</legend>
<!--Akzentfarbe -->
<div class="form-group">
<label class="col-md-4 control-label" for="textinput">Akzentfarbe<br />(für Überschriften, Links, Buttons)</label>
<div class="col-md-4">
<div id="maincolor" class="input-group colorpicker-component"> <input type="text" value="#4a8591" class="form-control" readonly/> <span class="input-group-addon"><i></i></span> </div>
<div id="colorcontraststatus"></div>
<script>
$(function() { $('#maincolor').colorpicker(); });
$(function() { $('#maincolor').colorpicker().on('changeColor', function(e) { PreviewColor(e.color.toString('rgba')); }); });
</script>
</div>
</div>
</fieldset>
<fieldset>
<!-- Überschriften -->
<div class="form-group">
<label class="col-md-4 control-label" for="textinput">Überschriften-Schriftart</label>
<div class="col-md-4">
<select id="headerfont" size="1" onchange="PreviewHeaderFont(this.value);">
<optgroup label="Serifen">
<option>Georgia, serif</option>
<option>"Palatino Linotype", "Book Antiqua", Palatino, serif</option>
<option>"Times New Roman", Times, serif</option>
</optgroup>
<optgroup label="Serifenlos">
<option selected>Arial, Helvetica, sans-serif</option>
<option>"Arial Black", Gadget, sans-serif</option>
<option>"Comic Sans MS", cursive, sans-serif</option>
<option>Impact, Charcoal, sans-serif</option>
<option>"Lucida Sans Unicode", "Lucida Grande", sans-serif</option>
<option>Tahoma, Geneva, sans-serif</option>
<option>"Trebuchet MS", Helvetica, sans-serif</option>
<option>Verdana, Geneva, sans-serif</option>
</optgroup>
<optgroup label="Monospace">
<option>"Courier New", Courier, monospace</option>
<option>"Lucida Console", Monaco, monospace</option>
</optgroup>
</select>
</div>
</div>
<!-- Body -->
<div class="form-group">
<label class="col-md-4 control-label" for="textinput">Hauptschriftart</label>
<div class="col-md-4">
<select id="bodyfont" size="1" onchange="PreviewBodyFont(this.value);">
<!-- Populated from #headerfont -->
</select>
</div>
</div>
</fieldset>
<fieldset style="margin-top: 2em;">
<div class="form-group">
<label class="col-md-4 control-label" for="download">Textvorschau</label>
<div class="col-md-8">
<div id="preview" style="font-family: Arial, Helvetica, sans-serif; color: #333333; padding: 1em; border: 1px solid #eee; min-height: 200px; width: 100%;"><h1>Überschrift 1</h1><p>Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod <a href=".">tempor invidunt ut labore et dolore</a> magna aliquyam erat, sed diam voluptua. At vero eos et accusam et justo duo dolores et ea rebum. Stet clita kasd gubergren, no sea takimata sanctus est Lorem ipsum dolor sit amet.<h2>Überschrift 2</h2>Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua.</p><input value="Schaltfläche" class="btn btn-primary" style="background-color: #4a8591; border: none;"></div>
</div>
</div>
</fieldset>
<fieldset>
<div class="form-group">
<label class="col-md-4 control-label" for="checkboxes">Weitere Darstellungsoptionen</label>
<div class="col-md-8">
<div class="checkbox">
<label for="kacheldesign">
<input type="checkbox" name="checkboxes" id="kacheldesign">
Kacheldesign für Übersicht von Strukturbausteinen
</label>
<p style="margin-top: 1em;"><b>Hinweis:</b> Wenn aktiviert, wird im Kurs für die Übersicht von Strukturbausteinen ein Kacheldesign aus dem jeweiligen Bausteintitel und der Bausteinbeschreibung verwendet.</p>
<p>
<a data-toggle="collapse" href="#kacheldesignhilfe" role="button" aria-expanded="false" aria-controls="collapse">Anleitung mit Vorschau für zweispaltiges Kacheldesign anzeigen
</a>
</p>
<div class="collapse" id="kacheldesignhilfe">
<ol>
<li>Im Kurs-Editor einen (obersten) Strukturbaustein aufrufen.</li>
<li>Im Reiter „Übersicht“ die Option „Anzeige in zwei Spalten“ aktivieren.</li>
</ol>
<video width="320" height="240" controls>
<source src="media/kacheldesign.mp4" type="video/mp4">
</video>
</div>
</div>
</div>
</div>
</fieldset>
<fieldset style="margin-top: 2em;">
<!-- Button -->
<div class="form-group">
<label class="col-md-4 control-label" for="download">Theme herunterladen</label>
<div class="col-md-4">
<input type="submit" name="download" value="Download" class="btn btn-primary">
</div>
</div>
</fieldset>
</form>
</div>
</div>
</div>
<div class="row" id="footer">
<div class="col-sm-3 col-sm-offset-1" style="text-align: center;">
<p>Autor: <a href="https://www.vcrp.de/author/fetzer" target="_blank">Raphael Fetzer</a></p>
<p>Version: <span id="version"></span></p>
</div>
<div class="col-sm-4" style="text-align: center;">
<p><a href="https://www.vcrp.de/service/datenschutzerklaerung" target="_blank">Datenschutzerklärung</a></p><p><a href="https://www.vcrp.de/service/impressum" target="_blank">Impressum</a></p>
</div>
<div class="col-sm-3" style="text-align: center; margin-bottom: 2em;">
<p><a onclick='showDevTools(true);'><img style="height: 60px;" src="media/vcrp-logo-2016.svg"></a></p>
</div>
</div>
</div>
<script>
var version = "0.2";
document.write("<script type='text/javascript' src='js/themebot.js?v=" + version + "'><\/script>");
</script>
</body>
</html>
/*! FileSaver.js
* A saveAs() FileSaver implementation.
* 2014-01-24
*
* By Eli Grey, http://eligrey.com
* License: X11/MIT
* See LICENSE.md
*/
/*global self */
/*jslint bitwise: true, indent: 4, laxbreak: true, laxcomma: true, smarttabs: true, plusplus: true */
/*! @source http://purl.eligrey.com/github/FileSaver.js/blob/master/FileSaver.js */
var saveAs = saveAs
// IE 10+ (native saveAs)
|| (typeof navigator !== "undefined" &&
navigator.msSaveOrOpenBlob && navigator.msSaveOrOpenBlob.bind(navigator))
// Everyone else
|| (function(view) {
"use strict";
// IE <10 is explicitly unsupported
if (typeof navigator !== "undefined" &&
/MSIE [1-9]\./.test(navigator.userAgent)) {
return;
}
var
doc = view.document
// only get URL when necessary in case BlobBuilder.js hasn't overridden it yet
, get_URL = function() {
return view.URL || view.webkitURL || view;
}
, URL = view.URL || view.webkitURL || view
, save_link = doc.createElementNS("http://www.w3.org/1999/xhtml", "a")
, can_use_save_link = !view.externalHost && "download" in save_link
, click = function(node) {
var event = doc.createEvent("MouseEvents");
event.initMouseEvent(
"click", true, false, view, 0, 0, 0, 0, 0
, false, false, false, false, 0, null
);
node.dispatchEvent(event);
}
, webkit_req_fs = view.webkitRequestFileSystem
, req_fs = view.requestFileSystem || webkit_req_fs || view.mozRequestFileSystem
, throw_outside = function(ex) {
(view.setImmediate || view.setTimeout)(function() {
throw ex;
}, 0);
}
, force_saveable_type = "application/octet-stream"
, fs_min_size = 0
, deletion_queue = []
, process_deletion_queue = function() {
var i = deletion_queue.length;
while (i--) {
var file = deletion_queue[i];
if (typeof file === "string") { // file is an object URL
URL.revokeObjectURL(file);
} else { // file is a File
file.remove();
}
}
deletion_queue.length = 0; // clear queue
}
, dispatch = function(filesaver, event_types, event) {
event_types = [].concat(event_types);
var i = event_types.length;
while (i--) {
var listener = filesaver["on" + event_types[i]];
if (typeof listener === "function") {
try {
listener.call(filesaver, event || filesaver);
} catch (ex) {
throw_outside(ex);
}
}
}
}
, FileSaver = function(blob, name) {
// First try a.download, then web filesystem, then object URLs
var
filesaver = this
, type = blob.type
, blob_changed = false
, object_url
, target_view
, get_object_url = function() {
var object_url = get_URL().createObjectURL(blob);
deletion_queue.push(object_url);
return object_url;
}
, dispatch_all = function() {
dispatch(filesaver, "writestart progress write writeend".split(" "));
}
// on any filesys errors revert to saving with object URLs
, fs_error = function() {
// don't create more object URLs than needed
if (blob_changed || !object_url) {
object_url = get_object_url(blob);
}
if (target_view) {
target_view.location.href = object_url;
} else {
window.open(object_url, "_blank");
}
filesaver.readyState = filesaver.DONE;
dispatch_all();
}
, abortable = function(func) {
return function() {
if (filesaver.readyState !== filesaver.DONE) {
return func.apply(this, arguments);
}
};
}
, create_if_not_found = {create: true, exclusive: false}
, slice
;
filesaver.readyState = filesaver.INIT;
if (!name) {
name = "download";
}
if (can_use_save_link) {
object_url = get_object_url(blob);
// FF for Android has a nasty garbage collection mechanism
// that turns all objects that are not pure javascript into 'deadObject'
// this means `doc` and `save_link` are unusable and need to be recreated
// `view` is usable though:
doc = view.document;
save_link = doc.createElementNS("http://www.w3.org/1999/xhtml", "a");
save_link.href = object_url;
save_link.download = name;
var event = doc.createEvent("MouseEvents");
event.initMouseEvent(
"click", true, false, view, 0, 0, 0, 0, 0
, false, false, false, false, 0, null
);
save_link.dispatchEvent(event);
filesaver.readyState = filesaver.DONE;
dispatch_all();
return;
}
// Object and web filesystem URLs have a problem saving in Google Chrome when
// viewed in a tab, so I force save with application/octet-stream
// http://code.google.com/p/chromium/issues/detail?id=91158
if (view.chrome && type && type !== force_saveable_type) {
slice = blob.slice || blob.webkitSlice;
blob = slice.call(blob, 0, blob.size, force_saveable_type);
blob_changed = true;
}
// Since I can't be sure that the guessed media type will trigger a download
// in WebKit, I append .download to the filename.
// https://bugs.webkit.org/show_bug.cgi?id=65440
if (webkit_req_fs && name !== "download") {
name += ".download";
}
if (type === force_saveable_type || webkit_req_fs) {
target_view = view;
}
if (!req_fs) {
fs_error();
return;
}
fs_min_size += blob.size;
req_fs(view.TEMPORARY, fs_min_size, abortable(function(fs) {
fs.root.getDirectory("saved", create_if_not_found, abortable(function(dir) {
var save = function() {
dir.getFile(name, create_if_not_found, abortable(function(file) {
file.createWriter(abortable(function(writer) {
writer.onwriteend = function(event) {
target_view.location.href = file.toURL();
deletion_queue.push(file);
filesaver.readyState = filesaver.DONE;
dispatch(filesaver, "writeend", event);
};
writer.onerror = function() {
var error = writer.error;
if (error.code !== error.ABORT_ERR) {
fs_error();
}
};
"writestart progress write abort".split(" ").forEach(function(event) {
writer["on" + event] = filesaver["on" + event];
});
writer.write(blob);
filesaver.abort = function() {
writer.abort();
filesaver.readyState = filesaver.DONE;
};
filesaver.readyState = filesaver.WRITING;
}), fs_error);
}), fs_error);
};
dir.getFile(name, {create: false}, abortable(function(file) {
// delete file if it already exists
file.remove();
save();
}), abortable(function(ex) {
if (ex.code === ex.NOT_FOUND_ERR) {
save();
} else {
fs_error();
}
}));
}), fs_error);
}), fs_error);
}
, FS_proto = FileSaver.prototype
, saveAs = function(blob, name) {
return new FileSaver(blob, name);
}
;
FS_proto.abort = function() {
var filesaver = this;
filesaver.readyState = filesaver.DONE;
dispatch(filesaver, "abort");
};
FS_proto.readyState = FS_proto.INIT = 0;
FS_proto.WRITING = 1;
FS_proto.DONE = 2;
FS_proto.error =
FS_proto.onwritestart =
FS_proto.onprogress =
FS_proto.onwrite =