From 6eca7ef591b9e3711a277d4d1ac3827ad6147198 Mon Sep 17 00:00:00 2001 From: Garulf Date: Wed, 31 Jan 2024 20:45:30 +0000 Subject: [PATCH] Deployed 6c40f14 with MkDocs version: 1.4.2 --- .nojekyll | 0 404.html | 454 ++ assets/_mkdocstrings.css | 109 + assets/images/favicon.png | Bin 0 -> 1870 bytes assets/javascripts/bundle.51d95adb.min.js | 29 + assets/javascripts/bundle.51d95adb.min.js.map | 8 + assets/javascripts/lunr/min/lunr.ar.min.js | 1 + assets/javascripts/lunr/min/lunr.da.min.js | 18 + assets/javascripts/lunr/min/lunr.de.min.js | 18 + assets/javascripts/lunr/min/lunr.du.min.js | 18 + assets/javascripts/lunr/min/lunr.es.min.js | 18 + assets/javascripts/lunr/min/lunr.fi.min.js | 18 + assets/javascripts/lunr/min/lunr.fr.min.js | 18 + assets/javascripts/lunr/min/lunr.hi.min.js | 1 + assets/javascripts/lunr/min/lunr.hu.min.js | 18 + assets/javascripts/lunr/min/lunr.it.min.js | 18 + assets/javascripts/lunr/min/lunr.ja.min.js | 1 + assets/javascripts/lunr/min/lunr.jp.min.js | 1 + assets/javascripts/lunr/min/lunr.ko.min.js | 1 + assets/javascripts/lunr/min/lunr.multi.min.js | 1 + assets/javascripts/lunr/min/lunr.nl.min.js | 18 + assets/javascripts/lunr/min/lunr.no.min.js | 18 + assets/javascripts/lunr/min/lunr.pt.min.js | 18 + assets/javascripts/lunr/min/lunr.ro.min.js | 18 + assets/javascripts/lunr/min/lunr.ru.min.js | 18 + .../lunr/min/lunr.stemmer.support.min.js | 1 + assets/javascripts/lunr/min/lunr.sv.min.js | 18 + assets/javascripts/lunr/min/lunr.ta.min.js | 1 + assets/javascripts/lunr/min/lunr.th.min.js | 1 + assets/javascripts/lunr/min/lunr.tr.min.js | 18 + assets/javascripts/lunr/min/lunr.vi.min.js | 1 + assets/javascripts/lunr/min/lunr.zh.min.js | 1 + assets/javascripts/lunr/tinyseg.js | 206 + assets/javascripts/lunr/wordcut.js | 6708 +++++++++++++++++ .../workers/search.e5c33ebb.min.js | 42 + .../workers/search.e5c33ebb.min.js.map | 8 + assets/stylesheets/main.558e4712.min.css | 1 + assets/stylesheets/main.558e4712.min.css.map | 1 + assets/stylesheets/palette.2505c338.min.css | 1 + .../stylesheets/palette.2505c338.min.css.map | 1 + examples/guide/api_requests/example1.py | 18 + examples/guide/api_requests/example2.py | 24 + examples/guide/launcher_icons/example1.py | 18 + examples/guide/plugin_methods/example1.py | 24 + examples/guide/plugin_methods/example2.py | 23 + examples/guide/scoring_results/example1.py | 20 + guide/API Requests/index.html | 603 ++ guide/Launcher_Icons/index.html | 562 ++ guide/Plugin methods/index.html | 603 ++ guide/scoring_results/index.html | 558 ++ index.html | 543 ++ objects.inv | Bin 0 -> 788 bytes reference/api/index.html | 1280 ++++ reference/event/index.html | 961 +++ reference/plugin/index.html | 1369 ++++ reference/result/index.html | 2132 ++++++ sitemap.xml | 48 + sitemap.xml.gz | Bin 0 -> 203 bytes 58 files changed, 16635 insertions(+) create mode 100644 .nojekyll create mode 100644 404.html create mode 100644 assets/_mkdocstrings.css create mode 100644 assets/images/favicon.png create mode 100644 assets/javascripts/bundle.51d95adb.min.js create mode 100644 assets/javascripts/bundle.51d95adb.min.js.map create mode 100644 assets/javascripts/lunr/min/lunr.ar.min.js create mode 100644 assets/javascripts/lunr/min/lunr.da.min.js create mode 100644 assets/javascripts/lunr/min/lunr.de.min.js create mode 100644 assets/javascripts/lunr/min/lunr.du.min.js create mode 100644 assets/javascripts/lunr/min/lunr.es.min.js create mode 100644 assets/javascripts/lunr/min/lunr.fi.min.js create mode 100644 assets/javascripts/lunr/min/lunr.fr.min.js create mode 100644 assets/javascripts/lunr/min/lunr.hi.min.js create mode 100644 assets/javascripts/lunr/min/lunr.hu.min.js create mode 100644 assets/javascripts/lunr/min/lunr.it.min.js create mode 100644 assets/javascripts/lunr/min/lunr.ja.min.js create mode 100644 assets/javascripts/lunr/min/lunr.jp.min.js create mode 100644 assets/javascripts/lunr/min/lunr.ko.min.js create mode 100644 assets/javascripts/lunr/min/lunr.multi.min.js create mode 100644 assets/javascripts/lunr/min/lunr.nl.min.js create mode 100644 assets/javascripts/lunr/min/lunr.no.min.js create mode 100644 assets/javascripts/lunr/min/lunr.pt.min.js create mode 100644 assets/javascripts/lunr/min/lunr.ro.min.js create mode 100644 assets/javascripts/lunr/min/lunr.ru.min.js create mode 100644 assets/javascripts/lunr/min/lunr.stemmer.support.min.js create mode 100644 assets/javascripts/lunr/min/lunr.sv.min.js create mode 100644 assets/javascripts/lunr/min/lunr.ta.min.js create mode 100644 assets/javascripts/lunr/min/lunr.th.min.js create mode 100644 assets/javascripts/lunr/min/lunr.tr.min.js create mode 100644 assets/javascripts/lunr/min/lunr.vi.min.js create mode 100644 assets/javascripts/lunr/min/lunr.zh.min.js create mode 100644 assets/javascripts/lunr/tinyseg.js create mode 100644 assets/javascripts/lunr/wordcut.js create mode 100644 assets/javascripts/workers/search.e5c33ebb.min.js create mode 100644 assets/javascripts/workers/search.e5c33ebb.min.js.map create mode 100644 assets/stylesheets/main.558e4712.min.css create mode 100644 assets/stylesheets/main.558e4712.min.css.map create mode 100644 assets/stylesheets/palette.2505c338.min.css create mode 100644 assets/stylesheets/palette.2505c338.min.css.map create mode 100644 examples/guide/api_requests/example1.py create mode 100644 examples/guide/api_requests/example2.py create mode 100644 examples/guide/launcher_icons/example1.py create mode 100644 examples/guide/plugin_methods/example1.py create mode 100644 examples/guide/plugin_methods/example2.py create mode 100644 examples/guide/scoring_results/example1.py create mode 100644 guide/API Requests/index.html create mode 100644 guide/Launcher_Icons/index.html create mode 100644 guide/Plugin methods/index.html create mode 100644 guide/scoring_results/index.html create mode 100644 index.html create mode 100644 objects.inv create mode 100644 reference/api/index.html create mode 100644 reference/event/index.html create mode 100644 reference/plugin/index.html create mode 100644 reference/result/index.html create mode 100644 sitemap.xml create mode 100644 sitemap.xml.gz diff --git a/.nojekyll b/.nojekyll new file mode 100644 index 0000000..e69de29 diff --git a/404.html b/404.html new file mode 100644 index 0000000..bbcf9c1 --- /dev/null +++ b/404.html @@ -0,0 +1,454 @@ + + + + + + + + + + + + + + + + + + PyFlowLauncher + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+
+ +
+ + + + +
+ + +
+ +
+ + + + + + +
+
+ + + +
+
+
+ + + + +
+
+
+ + + +
+
+
+ + + +
+
+
+ + + +
+
+ +

404 - Not found

+ +
+
+ + +
+ +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/assets/_mkdocstrings.css b/assets/_mkdocstrings.css new file mode 100644 index 0000000..4b7d98b --- /dev/null +++ b/assets/_mkdocstrings.css @@ -0,0 +1,109 @@ + +/* Avoid breaking parameter names, etc. in table cells. */ +.doc-contents td code { + word-break: normal !important; +} + +/* No line break before first paragraph of descriptions. */ +.doc-md-description, +.doc-md-description>p:first-child { + display: inline; +} + +/* Max width for docstring sections tables. */ +.doc .md-typeset__table, +.doc .md-typeset__table table { + display: table !important; + width: 100%; +} + +.doc .md-typeset__table tr { + display: table-row; +} + +/* Defaults in Spacy table style. */ +.doc-param-default { + float: right; +} + +/* Symbols in Navigation and ToC. */ +:root, +[data-md-color-scheme="default"] { + --doc-symbol-attribute-fg-color: #953800; + --doc-symbol-function-fg-color: #8250df; + --doc-symbol-method-fg-color: #8250df; + --doc-symbol-class-fg-color: #0550ae; + --doc-symbol-module-fg-color: #5cad0f; + + --doc-symbol-attribute-bg-color: #9538001a; + --doc-symbol-function-bg-color: #8250df1a; + --doc-symbol-method-bg-color: #8250df1a; + --doc-symbol-class-bg-color: #0550ae1a; + --doc-symbol-module-bg-color: #5cad0f1a; +} + +[data-md-color-scheme="slate"] { + --doc-symbol-attribute-fg-color: #ffa657; + --doc-symbol-function-fg-color: #d2a8ff; + --doc-symbol-method-fg-color: #d2a8ff; + --doc-symbol-class-fg-color: #79c0ff; + --doc-symbol-module-fg-color: #baff79; + + --doc-symbol-attribute-bg-color: #ffa6571a; + --doc-symbol-function-bg-color: #d2a8ff1a; + --doc-symbol-method-bg-color: #d2a8ff1a; + --doc-symbol-class-bg-color: #79c0ff1a; + --doc-symbol-module-bg-color: #baff791a; +} + +code.doc-symbol { + border-radius: .1rem; + font-size: .85em; + padding: 0 .3em; + font-weight: bold; +} + +code.doc-symbol-attribute { + color: var(--doc-symbol-attribute-fg-color); + background-color: var(--doc-symbol-attribute-bg-color); +} + +code.doc-symbol-attribute::after { + content: "attr"; +} + +code.doc-symbol-function { + color: var(--doc-symbol-function-fg-color); + background-color: var(--doc-symbol-function-bg-color); +} + +code.doc-symbol-function::after { + content: "func"; +} + +code.doc-symbol-method { + color: var(--doc-symbol-method-fg-color); + background-color: var(--doc-symbol-method-bg-color); +} + +code.doc-symbol-method::after { + content: "meth"; +} + +code.doc-symbol-class { + color: var(--doc-symbol-class-fg-color); + background-color: var(--doc-symbol-class-bg-color); +} + +code.doc-symbol-class::after { + content: "class"; +} + +code.doc-symbol-module { + color: var(--doc-symbol-module-fg-color); + background-color: var(--doc-symbol-module-bg-color); +} + +code.doc-symbol-module::after { + content: "mod"; +} \ No newline at end of file diff --git a/assets/images/favicon.png b/assets/images/favicon.png new file mode 100644 index 0000000000000000000000000000000000000000..1cf13b9f9d978896599290a74f77d5dbe7d1655c GIT binary patch literal 1870 zcmV-U2eJ5xP)Gc)JR9QMau)O=X#!i9;T z37kk-upj^(fsR36MHs_+1RCI)NNu9}lD0S{B^g8PN?Ww(5|~L#Ng*g{WsqleV}|#l zz8@ri&cTzw_h33bHI+12+kK6WN$h#n5cD8OQt`5kw6p~9H3()bUQ8OS4Q4HTQ=1Ol z_JAocz`fLbT2^{`8n~UAo=#AUOf=SOq4pYkt;XbC&f#7lb$*7=$na!mWCQ`dBQsO0 zLFBSPj*N?#u5&pf2t4XjEGH|=pPQ8xh7tpx;US5Cx_Ju;!O`ya-yF`)b%TEt5>eP1ZX~}sjjA%FJF?h7cX8=b!DZl<6%Cv z*G0uvvU+vmnpLZ2paivG-(cd*y3$hCIcsZcYOGh{$&)A6*XX&kXZd3G8m)G$Zz-LV z^GF3VAW^Mdv!)4OM8EgqRiz~*Cji;uzl2uC9^=8I84vNp;ltJ|q-*uQwGp2ma6cY7 z;`%`!9UXO@fr&Ebapfs34OmS9^u6$)bJxrucutf>`dKPKT%%*d3XlFVKunp9 zasduxjrjs>f8V=D|J=XNZp;_Zy^WgQ$9WDjgY=z@stwiEBm9u5*|34&1Na8BMjjgf3+SHcr`5~>oz1Y?SW^=K z^bTyO6>Gar#P_W2gEMwq)ot3; zREHn~U&Dp0l6YT0&k-wLwYjb?5zGK`W6S2v+K>AM(95m2C20L|3m~rN8dprPr@t)5lsk9Hu*W z?pS990s;Ez=+Rj{x7p``4>+c0G5^pYnB1^!TL=(?HLHZ+HicG{~4F1d^5Awl_2!1jICM-!9eoLhbbT^;yHcefyTAaqRcY zmuctDopPT!%k+}x%lZRKnzykr2}}XfG_ne?nRQO~?%hkzo;@RN{P6o`&mMUWBYMTe z6i8ChtjX&gXl`nvrU>jah)2iNM%JdjqoaeaU%yVn!^70x-flljp6Q5tK}5}&X8&&G zX3fpb3E(!rH=zVI_9Gjl45w@{(ITqngWFe7@9{mX;tO25Z_8 zQHEpI+FkTU#4xu>RkN>b3Tnc3UpWzPXWm#o55GKF09j^Mh~)K7{QqbO_~(@CVq! zS<8954|P8mXN2MRs86xZ&Q4EfM@JB94b=(YGuk)s&^jiSF=t3*oNK3`rD{H`yQ?d; ztE=laAUoZx5?RC8*WKOj`%LXEkgDd>&^Q4M^z`%u0rg-It=hLCVsq!Z%^6eB-OvOT zFZ28TN&cRmgU}Elrnk43)!>Z1FCPL2K$7}gwzIc48NX}#!A1BpJP?#v5wkNprhV** z?Cpalt1oH&{r!o3eSKc&ap)iz2BTn_VV`4>9M^b3;(YY}4>#ML6{~(4mH+?%07*qo IM6N<$f(jP3KmY&$ literal 0 HcmV?d00001 diff --git a/assets/javascripts/bundle.51d95adb.min.js b/assets/javascripts/bundle.51d95adb.min.js new file mode 100644 index 0000000..b20ec68 --- /dev/null +++ b/assets/javascripts/bundle.51d95adb.min.js @@ -0,0 +1,29 @@ +"use strict";(()=>{var Hi=Object.create;var xr=Object.defineProperty;var Pi=Object.getOwnPropertyDescriptor;var $i=Object.getOwnPropertyNames,kt=Object.getOwnPropertySymbols,Ii=Object.getPrototypeOf,Er=Object.prototype.hasOwnProperty,an=Object.prototype.propertyIsEnumerable;var on=(e,t,r)=>t in e?xr(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,P=(e,t)=>{for(var r in t||(t={}))Er.call(t,r)&&on(e,r,t[r]);if(kt)for(var r of kt(t))an.call(t,r)&&on(e,r,t[r]);return e};var sn=(e,t)=>{var r={};for(var n in e)Er.call(e,n)&&t.indexOf(n)<0&&(r[n]=e[n]);if(e!=null&&kt)for(var n of kt(e))t.indexOf(n)<0&&an.call(e,n)&&(r[n]=e[n]);return r};var Ht=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports);var Fi=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of $i(t))!Er.call(e,o)&&o!==r&&xr(e,o,{get:()=>t[o],enumerable:!(n=Pi(t,o))||n.enumerable});return e};var yt=(e,t,r)=>(r=e!=null?Hi(Ii(e)):{},Fi(t||!e||!e.__esModule?xr(r,"default",{value:e,enumerable:!0}):r,e));var fn=Ht((wr,cn)=>{(function(e,t){typeof wr=="object"&&typeof cn!="undefined"?t():typeof define=="function"&&define.amd?define(t):t()})(wr,function(){"use strict";function e(r){var n=!0,o=!1,i=null,a={text:!0,search:!0,url:!0,tel:!0,email:!0,password:!0,number:!0,date:!0,month:!0,week:!0,time:!0,datetime:!0,"datetime-local":!0};function s(T){return!!(T&&T!==document&&T.nodeName!=="HTML"&&T.nodeName!=="BODY"&&"classList"in T&&"contains"in T.classList)}function f(T){var Ke=T.type,We=T.tagName;return!!(We==="INPUT"&&a[Ke]&&!T.readOnly||We==="TEXTAREA"&&!T.readOnly||T.isContentEditable)}function c(T){T.classList.contains("focus-visible")||(T.classList.add("focus-visible"),T.setAttribute("data-focus-visible-added",""))}function u(T){T.hasAttribute("data-focus-visible-added")&&(T.classList.remove("focus-visible"),T.removeAttribute("data-focus-visible-added"))}function p(T){T.metaKey||T.altKey||T.ctrlKey||(s(r.activeElement)&&c(r.activeElement),n=!0)}function m(T){n=!1}function d(T){s(T.target)&&(n||f(T.target))&&c(T.target)}function h(T){s(T.target)&&(T.target.classList.contains("focus-visible")||T.target.hasAttribute("data-focus-visible-added"))&&(o=!0,window.clearTimeout(i),i=window.setTimeout(function(){o=!1},100),u(T.target))}function v(T){document.visibilityState==="hidden"&&(o&&(n=!0),B())}function B(){document.addEventListener("mousemove",z),document.addEventListener("mousedown",z),document.addEventListener("mouseup",z),document.addEventListener("pointermove",z),document.addEventListener("pointerdown",z),document.addEventListener("pointerup",z),document.addEventListener("touchmove",z),document.addEventListener("touchstart",z),document.addEventListener("touchend",z)}function re(){document.removeEventListener("mousemove",z),document.removeEventListener("mousedown",z),document.removeEventListener("mouseup",z),document.removeEventListener("pointermove",z),document.removeEventListener("pointerdown",z),document.removeEventListener("pointerup",z),document.removeEventListener("touchmove",z),document.removeEventListener("touchstart",z),document.removeEventListener("touchend",z)}function z(T){T.target.nodeName&&T.target.nodeName.toLowerCase()==="html"||(n=!1,re())}document.addEventListener("keydown",p,!0),document.addEventListener("mousedown",m,!0),document.addEventListener("pointerdown",m,!0),document.addEventListener("touchstart",m,!0),document.addEventListener("visibilitychange",v,!0),B(),r.addEventListener("focus",d,!0),r.addEventListener("blur",h,!0),r.nodeType===Node.DOCUMENT_FRAGMENT_NODE&&r.host?r.host.setAttribute("data-js-focus-visible",""):r.nodeType===Node.DOCUMENT_NODE&&(document.documentElement.classList.add("js-focus-visible"),document.documentElement.setAttribute("data-js-focus-visible",""))}if(typeof window!="undefined"&&typeof document!="undefined"){window.applyFocusVisiblePolyfill=e;var t;try{t=new CustomEvent("focus-visible-polyfill-ready")}catch(r){t=document.createEvent("CustomEvent"),t.initCustomEvent("focus-visible-polyfill-ready",!1,!1,{})}window.dispatchEvent(t)}typeof document!="undefined"&&e(document)})});var un=Ht(Sr=>{(function(e){var t=function(){try{return!!Symbol.iterator}catch(c){return!1}},r=t(),n=function(c){var u={next:function(){var p=c.shift();return{done:p===void 0,value:p}}};return r&&(u[Symbol.iterator]=function(){return u}),u},o=function(c){return encodeURIComponent(c).replace(/%20/g,"+")},i=function(c){return decodeURIComponent(String(c).replace(/\+/g," "))},a=function(){var c=function(p){Object.defineProperty(this,"_entries",{writable:!0,value:{}});var m=typeof p;if(m!=="undefined")if(m==="string")p!==""&&this._fromString(p);else if(p instanceof c){var d=this;p.forEach(function(re,z){d.append(z,re)})}else if(p!==null&&m==="object")if(Object.prototype.toString.call(p)==="[object Array]")for(var h=0;hd[0]?1:0}),c._entries&&(c._entries={});for(var p=0;p1?i(d[1]):"")}})})(typeof global!="undefined"?global:typeof window!="undefined"?window:typeof self!="undefined"?self:Sr);(function(e){var t=function(){try{var o=new e.URL("b","http://a");return o.pathname="c d",o.href==="http://a/c%20d"&&o.searchParams}catch(i){return!1}},r=function(){var o=e.URL,i=function(f,c){typeof f!="string"&&(f=String(f)),c&&typeof c!="string"&&(c=String(c));var u=document,p;if(c&&(e.location===void 0||c!==e.location.href)){c=c.toLowerCase(),u=document.implementation.createHTMLDocument(""),p=u.createElement("base"),p.href=c,u.head.appendChild(p);try{if(p.href.indexOf(c)!==0)throw new Error(p.href)}catch(T){throw new Error("URL unable to set base "+c+" due to "+T)}}var m=u.createElement("a");m.href=f,p&&(u.body.appendChild(m),m.href=m.href);var d=u.createElement("input");if(d.type="url",d.value=f,m.protocol===":"||!/:/.test(m.href)||!d.checkValidity()&&!c)throw new TypeError("Invalid URL");Object.defineProperty(this,"_anchorElement",{value:m});var h=new e.URLSearchParams(this.search),v=!0,B=!0,re=this;["append","delete","set"].forEach(function(T){var Ke=h[T];h[T]=function(){Ke.apply(h,arguments),v&&(B=!1,re.search=h.toString(),B=!0)}}),Object.defineProperty(this,"searchParams",{value:h,enumerable:!0});var z=void 0;Object.defineProperty(this,"_updateSearchParams",{enumerable:!1,configurable:!1,writable:!1,value:function(){this.search!==z&&(z=this.search,B&&(v=!1,this.searchParams._fromString(this.search),v=!0))}})},a=i.prototype,s=function(f){Object.defineProperty(a,f,{get:function(){return this._anchorElement[f]},set:function(c){this._anchorElement[f]=c},enumerable:!0})};["hash","host","hostname","port","protocol"].forEach(function(f){s(f)}),Object.defineProperty(a,"search",{get:function(){return this._anchorElement.search},set:function(f){this._anchorElement.search=f,this._updateSearchParams()},enumerable:!0}),Object.defineProperties(a,{toString:{get:function(){var f=this;return function(){return f.href}}},href:{get:function(){return this._anchorElement.href.replace(/\?$/,"")},set:function(f){this._anchorElement.href=f,this._updateSearchParams()},enumerable:!0},pathname:{get:function(){return this._anchorElement.pathname.replace(/(^\/?)/,"/")},set:function(f){this._anchorElement.pathname=f},enumerable:!0},origin:{get:function(){var f={"http:":80,"https:":443,"ftp:":21}[this._anchorElement.protocol],c=this._anchorElement.port!=f&&this._anchorElement.port!=="";return this._anchorElement.protocol+"//"+this._anchorElement.hostname+(c?":"+this._anchorElement.port:"")},enumerable:!0},password:{get:function(){return""},set:function(f){},enumerable:!0},username:{get:function(){return""},set:function(f){},enumerable:!0}}),i.createObjectURL=function(f){return o.createObjectURL.apply(o,arguments)},i.revokeObjectURL=function(f){return o.revokeObjectURL.apply(o,arguments)},e.URL=i};if(t()||r(),e.location!==void 0&&!("origin"in e.location)){var n=function(){return e.location.protocol+"//"+e.location.hostname+(e.location.port?":"+e.location.port:"")};try{Object.defineProperty(e.location,"origin",{get:n,enumerable:!0})}catch(o){setInterval(function(){e.location.origin=n()},100)}}})(typeof global!="undefined"?global:typeof window!="undefined"?window:typeof self!="undefined"?self:Sr)});var Qr=Ht((Lt,Kr)=>{/*! + * clipboard.js v2.0.11 + * https://clipboardjs.com/ + * + * Licensed MIT © Zeno Rocha + */(function(t,r){typeof Lt=="object"&&typeof Kr=="object"?Kr.exports=r():typeof define=="function"&&define.amd?define([],r):typeof Lt=="object"?Lt.ClipboardJS=r():t.ClipboardJS=r()})(Lt,function(){return function(){var e={686:function(n,o,i){"use strict";i.d(o,{default:function(){return ki}});var a=i(279),s=i.n(a),f=i(370),c=i.n(f),u=i(817),p=i.n(u);function m(j){try{return document.execCommand(j)}catch(O){return!1}}var d=function(O){var w=p()(O);return m("cut"),w},h=d;function v(j){var O=document.documentElement.getAttribute("dir")==="rtl",w=document.createElement("textarea");w.style.fontSize="12pt",w.style.border="0",w.style.padding="0",w.style.margin="0",w.style.position="absolute",w.style[O?"right":"left"]="-9999px";var k=window.pageYOffset||document.documentElement.scrollTop;return w.style.top="".concat(k,"px"),w.setAttribute("readonly",""),w.value=j,w}var B=function(O,w){var k=v(O);w.container.appendChild(k);var F=p()(k);return m("copy"),k.remove(),F},re=function(O){var w=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{container:document.body},k="";return typeof O=="string"?k=B(O,w):O instanceof HTMLInputElement&&!["text","search","url","tel","password"].includes(O==null?void 0:O.type)?k=B(O.value,w):(k=p()(O),m("copy")),k},z=re;function T(j){return typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?T=function(w){return typeof w}:T=function(w){return w&&typeof Symbol=="function"&&w.constructor===Symbol&&w!==Symbol.prototype?"symbol":typeof w},T(j)}var Ke=function(){var O=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},w=O.action,k=w===void 0?"copy":w,F=O.container,q=O.target,Le=O.text;if(k!=="copy"&&k!=="cut")throw new Error('Invalid "action" value, use either "copy" or "cut"');if(q!==void 0)if(q&&T(q)==="object"&&q.nodeType===1){if(k==="copy"&&q.hasAttribute("disabled"))throw new Error('Invalid "target" attribute. Please use "readonly" instead of "disabled" attribute');if(k==="cut"&&(q.hasAttribute("readonly")||q.hasAttribute("disabled")))throw new Error(`Invalid "target" attribute. You can't cut text from elements with "readonly" or "disabled" attributes`)}else throw new Error('Invalid "target" value, use a valid Element');if(Le)return z(Le,{container:F});if(q)return k==="cut"?h(q):z(q,{container:F})},We=Ke;function Ie(j){return typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?Ie=function(w){return typeof w}:Ie=function(w){return w&&typeof Symbol=="function"&&w.constructor===Symbol&&w!==Symbol.prototype?"symbol":typeof w},Ie(j)}function Ti(j,O){if(!(j instanceof O))throw new TypeError("Cannot call a class as a function")}function nn(j,O){for(var w=0;w0&&arguments[0]!==void 0?arguments[0]:{};this.action=typeof F.action=="function"?F.action:this.defaultAction,this.target=typeof F.target=="function"?F.target:this.defaultTarget,this.text=typeof F.text=="function"?F.text:this.defaultText,this.container=Ie(F.container)==="object"?F.container:document.body}},{key:"listenClick",value:function(F){var q=this;this.listener=c()(F,"click",function(Le){return q.onClick(Le)})}},{key:"onClick",value:function(F){var q=F.delegateTarget||F.currentTarget,Le=this.action(q)||"copy",Rt=We({action:Le,container:this.container,target:this.target(q),text:this.text(q)});this.emit(Rt?"success":"error",{action:Le,text:Rt,trigger:q,clearSelection:function(){q&&q.focus(),window.getSelection().removeAllRanges()}})}},{key:"defaultAction",value:function(F){return yr("action",F)}},{key:"defaultTarget",value:function(F){var q=yr("target",F);if(q)return document.querySelector(q)}},{key:"defaultText",value:function(F){return yr("text",F)}},{key:"destroy",value:function(){this.listener.destroy()}}],[{key:"copy",value:function(F){var q=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{container:document.body};return z(F,q)}},{key:"cut",value:function(F){return h(F)}},{key:"isSupported",value:function(){var F=arguments.length>0&&arguments[0]!==void 0?arguments[0]:["copy","cut"],q=typeof F=="string"?[F]:F,Le=!!document.queryCommandSupported;return q.forEach(function(Rt){Le=Le&&!!document.queryCommandSupported(Rt)}),Le}}]),w}(s()),ki=Ri},828:function(n){var o=9;if(typeof Element!="undefined"&&!Element.prototype.matches){var i=Element.prototype;i.matches=i.matchesSelector||i.mozMatchesSelector||i.msMatchesSelector||i.oMatchesSelector||i.webkitMatchesSelector}function a(s,f){for(;s&&s.nodeType!==o;){if(typeof s.matches=="function"&&s.matches(f))return s;s=s.parentNode}}n.exports=a},438:function(n,o,i){var a=i(828);function s(u,p,m,d,h){var v=c.apply(this,arguments);return u.addEventListener(m,v,h),{destroy:function(){u.removeEventListener(m,v,h)}}}function f(u,p,m,d,h){return typeof u.addEventListener=="function"?s.apply(null,arguments):typeof m=="function"?s.bind(null,document).apply(null,arguments):(typeof u=="string"&&(u=document.querySelectorAll(u)),Array.prototype.map.call(u,function(v){return s(v,p,m,d,h)}))}function c(u,p,m,d){return function(h){h.delegateTarget=a(h.target,p),h.delegateTarget&&d.call(u,h)}}n.exports=f},879:function(n,o){o.node=function(i){return i!==void 0&&i instanceof HTMLElement&&i.nodeType===1},o.nodeList=function(i){var a=Object.prototype.toString.call(i);return i!==void 0&&(a==="[object NodeList]"||a==="[object HTMLCollection]")&&"length"in i&&(i.length===0||o.node(i[0]))},o.string=function(i){return typeof i=="string"||i instanceof String},o.fn=function(i){var a=Object.prototype.toString.call(i);return a==="[object Function]"}},370:function(n,o,i){var a=i(879),s=i(438);function f(m,d,h){if(!m&&!d&&!h)throw new Error("Missing required arguments");if(!a.string(d))throw new TypeError("Second argument must be a String");if(!a.fn(h))throw new TypeError("Third argument must be a Function");if(a.node(m))return c(m,d,h);if(a.nodeList(m))return u(m,d,h);if(a.string(m))return p(m,d,h);throw new TypeError("First argument must be a String, HTMLElement, HTMLCollection, or NodeList")}function c(m,d,h){return m.addEventListener(d,h),{destroy:function(){m.removeEventListener(d,h)}}}function u(m,d,h){return Array.prototype.forEach.call(m,function(v){v.addEventListener(d,h)}),{destroy:function(){Array.prototype.forEach.call(m,function(v){v.removeEventListener(d,h)})}}}function p(m,d,h){return s(document.body,m,d,h)}n.exports=f},817:function(n){function o(i){var a;if(i.nodeName==="SELECT")i.focus(),a=i.value;else if(i.nodeName==="INPUT"||i.nodeName==="TEXTAREA"){var s=i.hasAttribute("readonly");s||i.setAttribute("readonly",""),i.select(),i.setSelectionRange(0,i.value.length),s||i.removeAttribute("readonly"),a=i.value}else{i.hasAttribute("contenteditable")&&i.focus();var f=window.getSelection(),c=document.createRange();c.selectNodeContents(i),f.removeAllRanges(),f.addRange(c),a=f.toString()}return a}n.exports=o},279:function(n){function o(){}o.prototype={on:function(i,a,s){var f=this.e||(this.e={});return(f[i]||(f[i]=[])).push({fn:a,ctx:s}),this},once:function(i,a,s){var f=this;function c(){f.off(i,c),a.apply(s,arguments)}return c._=a,this.on(i,c,s)},emit:function(i){var a=[].slice.call(arguments,1),s=((this.e||(this.e={}))[i]||[]).slice(),f=0,c=s.length;for(f;f{"use strict";/*! + * escape-html + * Copyright(c) 2012-2013 TJ Holowaychuk + * Copyright(c) 2015 Andreas Lubbe + * Copyright(c) 2015 Tiancheng "Timothy" Gu + * MIT Licensed + */var is=/["'&<>]/;Jo.exports=as;function as(e){var t=""+e,r=is.exec(t);if(!r)return t;var n,o="",i=0,a=0;for(i=r.index;i0&&i[i.length-1])&&(c[0]===6||c[0]===2)){r=0;continue}if(c[0]===3&&(!i||c[1]>i[0]&&c[1]=e.length&&(e=void 0),{value:e&&e[n++],done:!e}}};throw new TypeError(t?"Object is not iterable.":"Symbol.iterator is not defined.")}function W(e,t){var r=typeof Symbol=="function"&&e[Symbol.iterator];if(!r)return e;var n=r.call(e),o,i=[],a;try{for(;(t===void 0||t-- >0)&&!(o=n.next()).done;)i.push(o.value)}catch(s){a={error:s}}finally{try{o&&!o.done&&(r=n.return)&&r.call(n)}finally{if(a)throw a.error}}return i}function D(e,t,r){if(r||arguments.length===2)for(var n=0,o=t.length,i;n1||s(m,d)})})}function s(m,d){try{f(n[m](d))}catch(h){p(i[0][3],h)}}function f(m){m.value instanceof Xe?Promise.resolve(m.value.v).then(c,u):p(i[0][2],m)}function c(m){s("next",m)}function u(m){s("throw",m)}function p(m,d){m(d),i.shift(),i.length&&s(i[0][0],i[0][1])}}function mn(e){if(!Symbol.asyncIterator)throw new TypeError("Symbol.asyncIterator is not defined.");var t=e[Symbol.asyncIterator],r;return t?t.call(e):(e=typeof xe=="function"?xe(e):e[Symbol.iterator](),r={},n("next"),n("throw"),n("return"),r[Symbol.asyncIterator]=function(){return this},r);function n(i){r[i]=e[i]&&function(a){return new Promise(function(s,f){a=e[i](a),o(s,f,a.done,a.value)})}}function o(i,a,s,f){Promise.resolve(f).then(function(c){i({value:c,done:s})},a)}}function A(e){return typeof e=="function"}function at(e){var t=function(n){Error.call(n),n.stack=new Error().stack},r=e(t);return r.prototype=Object.create(Error.prototype),r.prototype.constructor=r,r}var $t=at(function(e){return function(r){e(this),this.message=r?r.length+` errors occurred during unsubscription: +`+r.map(function(n,o){return o+1+") "+n.toString()}).join(` + `):"",this.name="UnsubscriptionError",this.errors=r}});function De(e,t){if(e){var r=e.indexOf(t);0<=r&&e.splice(r,1)}}var Fe=function(){function e(t){this.initialTeardown=t,this.closed=!1,this._parentage=null,this._finalizers=null}return e.prototype.unsubscribe=function(){var t,r,n,o,i;if(!this.closed){this.closed=!0;var a=this._parentage;if(a)if(this._parentage=null,Array.isArray(a))try{for(var s=xe(a),f=s.next();!f.done;f=s.next()){var c=f.value;c.remove(this)}}catch(v){t={error:v}}finally{try{f&&!f.done&&(r=s.return)&&r.call(s)}finally{if(t)throw t.error}}else a.remove(this);var u=this.initialTeardown;if(A(u))try{u()}catch(v){i=v instanceof $t?v.errors:[v]}var p=this._finalizers;if(p){this._finalizers=null;try{for(var m=xe(p),d=m.next();!d.done;d=m.next()){var h=d.value;try{dn(h)}catch(v){i=i!=null?i:[],v instanceof $t?i=D(D([],W(i)),W(v.errors)):i.push(v)}}}catch(v){n={error:v}}finally{try{d&&!d.done&&(o=m.return)&&o.call(m)}finally{if(n)throw n.error}}}if(i)throw new $t(i)}},e.prototype.add=function(t){var r;if(t&&t!==this)if(this.closed)dn(t);else{if(t instanceof e){if(t.closed||t._hasParent(this))return;t._addParent(this)}(this._finalizers=(r=this._finalizers)!==null&&r!==void 0?r:[]).push(t)}},e.prototype._hasParent=function(t){var r=this._parentage;return r===t||Array.isArray(r)&&r.includes(t)},e.prototype._addParent=function(t){var r=this._parentage;this._parentage=Array.isArray(r)?(r.push(t),r):r?[r,t]:t},e.prototype._removeParent=function(t){var r=this._parentage;r===t?this._parentage=null:Array.isArray(r)&&De(r,t)},e.prototype.remove=function(t){var r=this._finalizers;r&&De(r,t),t instanceof e&&t._removeParent(this)},e.EMPTY=function(){var t=new e;return t.closed=!0,t}(),e}();var Or=Fe.EMPTY;function It(e){return e instanceof Fe||e&&"closed"in e&&A(e.remove)&&A(e.add)&&A(e.unsubscribe)}function dn(e){A(e)?e():e.unsubscribe()}var Ae={onUnhandledError:null,onStoppedNotification:null,Promise:void 0,useDeprecatedSynchronousErrorHandling:!1,useDeprecatedNextContext:!1};var st={setTimeout:function(e,t){for(var r=[],n=2;n0},enumerable:!1,configurable:!0}),t.prototype._trySubscribe=function(r){return this._throwIfClosed(),e.prototype._trySubscribe.call(this,r)},t.prototype._subscribe=function(r){return this._throwIfClosed(),this._checkFinalizedStatuses(r),this._innerSubscribe(r)},t.prototype._innerSubscribe=function(r){var n=this,o=this,i=o.hasError,a=o.isStopped,s=o.observers;return i||a?Or:(this.currentObservers=null,s.push(r),new Fe(function(){n.currentObservers=null,De(s,r)}))},t.prototype._checkFinalizedStatuses=function(r){var n=this,o=n.hasError,i=n.thrownError,a=n.isStopped;o?r.error(i):a&&r.complete()},t.prototype.asObservable=function(){var r=new U;return r.source=this,r},t.create=function(r,n){return new wn(r,n)},t}(U);var wn=function(e){ne(t,e);function t(r,n){var o=e.call(this)||this;return o.destination=r,o.source=n,o}return t.prototype.next=function(r){var n,o;(o=(n=this.destination)===null||n===void 0?void 0:n.next)===null||o===void 0||o.call(n,r)},t.prototype.error=function(r){var n,o;(o=(n=this.destination)===null||n===void 0?void 0:n.error)===null||o===void 0||o.call(n,r)},t.prototype.complete=function(){var r,n;(n=(r=this.destination)===null||r===void 0?void 0:r.complete)===null||n===void 0||n.call(r)},t.prototype._subscribe=function(r){var n,o;return(o=(n=this.source)===null||n===void 0?void 0:n.subscribe(r))!==null&&o!==void 0?o:Or},t}(E);var Et={now:function(){return(Et.delegate||Date).now()},delegate:void 0};var wt=function(e){ne(t,e);function t(r,n,o){r===void 0&&(r=1/0),n===void 0&&(n=1/0),o===void 0&&(o=Et);var i=e.call(this)||this;return i._bufferSize=r,i._windowTime=n,i._timestampProvider=o,i._buffer=[],i._infiniteTimeWindow=!0,i._infiniteTimeWindow=n===1/0,i._bufferSize=Math.max(1,r),i._windowTime=Math.max(1,n),i}return t.prototype.next=function(r){var n=this,o=n.isStopped,i=n._buffer,a=n._infiniteTimeWindow,s=n._timestampProvider,f=n._windowTime;o||(i.push(r),!a&&i.push(s.now()+f)),this._trimBuffer(),e.prototype.next.call(this,r)},t.prototype._subscribe=function(r){this._throwIfClosed(),this._trimBuffer();for(var n=this._innerSubscribe(r),o=this,i=o._infiniteTimeWindow,a=o._buffer,s=a.slice(),f=0;f0?e.prototype.requestAsyncId.call(this,r,n,o):(r.actions.push(this),r._scheduled||(r._scheduled=ut.requestAnimationFrame(function(){return r.flush(void 0)})))},t.prototype.recycleAsyncId=function(r,n,o){var i;if(o===void 0&&(o=0),o!=null?o>0:this.delay>0)return e.prototype.recycleAsyncId.call(this,r,n,o);var a=r.actions;n!=null&&((i=a[a.length-1])===null||i===void 0?void 0:i.id)!==n&&(ut.cancelAnimationFrame(n),r._scheduled=void 0)},t}(Ut);var On=function(e){ne(t,e);function t(){return e!==null&&e.apply(this,arguments)||this}return t.prototype.flush=function(r){this._active=!0;var n=this._scheduled;this._scheduled=void 0;var o=this.actions,i;r=r||o.shift();do if(i=r.execute(r.state,r.delay))break;while((r=o[0])&&r.id===n&&o.shift());if(this._active=!1,i){for(;(r=o[0])&&r.id===n&&o.shift();)r.unsubscribe();throw i}},t}(Wt);var we=new On(Tn);var R=new U(function(e){return e.complete()});function Dt(e){return e&&A(e.schedule)}function kr(e){return e[e.length-1]}function Qe(e){return A(kr(e))?e.pop():void 0}function Se(e){return Dt(kr(e))?e.pop():void 0}function Vt(e,t){return typeof kr(e)=="number"?e.pop():t}var pt=function(e){return e&&typeof e.length=="number"&&typeof e!="function"};function zt(e){return A(e==null?void 0:e.then)}function Nt(e){return A(e[ft])}function qt(e){return Symbol.asyncIterator&&A(e==null?void 0:e[Symbol.asyncIterator])}function Kt(e){return new TypeError("You provided "+(e!==null&&typeof e=="object"?"an invalid object":"'"+e+"'")+" where a stream was expected. You can provide an Observable, Promise, ReadableStream, Array, AsyncIterable, or Iterable.")}function Ki(){return typeof Symbol!="function"||!Symbol.iterator?"@@iterator":Symbol.iterator}var Qt=Ki();function Yt(e){return A(e==null?void 0:e[Qt])}function Gt(e){return ln(this,arguments,function(){var r,n,o,i;return Pt(this,function(a){switch(a.label){case 0:r=e.getReader(),a.label=1;case 1:a.trys.push([1,,9,10]),a.label=2;case 2:return[4,Xe(r.read())];case 3:return n=a.sent(),o=n.value,i=n.done,i?[4,Xe(void 0)]:[3,5];case 4:return[2,a.sent()];case 5:return[4,Xe(o)];case 6:return[4,a.sent()];case 7:return a.sent(),[3,2];case 8:return[3,10];case 9:return r.releaseLock(),[7];case 10:return[2]}})})}function Bt(e){return A(e==null?void 0:e.getReader)}function $(e){if(e instanceof U)return e;if(e!=null){if(Nt(e))return Qi(e);if(pt(e))return Yi(e);if(zt(e))return Gi(e);if(qt(e))return _n(e);if(Yt(e))return Bi(e);if(Bt(e))return Ji(e)}throw Kt(e)}function Qi(e){return new U(function(t){var r=e[ft]();if(A(r.subscribe))return r.subscribe(t);throw new TypeError("Provided object does not correctly implement Symbol.observable")})}function Yi(e){return new U(function(t){for(var r=0;r=2;return function(n){return n.pipe(e?_(function(o,i){return e(o,i,n)}):me,Oe(1),r?He(t):zn(function(){return new Xt}))}}function Nn(){for(var e=[],t=0;t=2,!0))}function fe(e){e===void 0&&(e={});var t=e.connector,r=t===void 0?function(){return new E}:t,n=e.resetOnError,o=n===void 0?!0:n,i=e.resetOnComplete,a=i===void 0?!0:i,s=e.resetOnRefCountZero,f=s===void 0?!0:s;return function(c){var u,p,m,d=0,h=!1,v=!1,B=function(){p==null||p.unsubscribe(),p=void 0},re=function(){B(),u=m=void 0,h=v=!1},z=function(){var T=u;re(),T==null||T.unsubscribe()};return g(function(T,Ke){d++,!v&&!h&&B();var We=m=m!=null?m:r();Ke.add(function(){d--,d===0&&!v&&!h&&(p=jr(z,f))}),We.subscribe(Ke),!u&&d>0&&(u=new et({next:function(Ie){return We.next(Ie)},error:function(Ie){v=!0,B(),p=jr(re,o,Ie),We.error(Ie)},complete:function(){h=!0,B(),p=jr(re,a),We.complete()}}),$(T).subscribe(u))})(c)}}function jr(e,t){for(var r=[],n=2;ne.next(document)),e}function K(e,t=document){return Array.from(t.querySelectorAll(e))}function V(e,t=document){let r=se(e,t);if(typeof r=="undefined")throw new ReferenceError(`Missing element: expected "${e}" to be present`);return r}function se(e,t=document){return t.querySelector(e)||void 0}function _e(){return document.activeElement instanceof HTMLElement&&document.activeElement||void 0}function tr(e){return L(b(document.body,"focusin"),b(document.body,"focusout")).pipe(ke(1),l(()=>{let t=_e();return typeof t!="undefined"?e.contains(t):!1}),N(e===_e()),Y())}function Be(e){return{x:e.offsetLeft,y:e.offsetTop}}function Yn(e){return L(b(window,"load"),b(window,"resize")).pipe(Ce(0,we),l(()=>Be(e)),N(Be(e)))}function rr(e){return{x:e.scrollLeft,y:e.scrollTop}}function dt(e){return L(b(e,"scroll"),b(window,"resize")).pipe(Ce(0,we),l(()=>rr(e)),N(rr(e)))}var Bn=function(){if(typeof Map!="undefined")return Map;function e(t,r){var n=-1;return t.some(function(o,i){return o[0]===r?(n=i,!0):!1}),n}return function(){function t(){this.__entries__=[]}return Object.defineProperty(t.prototype,"size",{get:function(){return this.__entries__.length},enumerable:!0,configurable:!0}),t.prototype.get=function(r){var n=e(this.__entries__,r),o=this.__entries__[n];return o&&o[1]},t.prototype.set=function(r,n){var o=e(this.__entries__,r);~o?this.__entries__[o][1]=n:this.__entries__.push([r,n])},t.prototype.delete=function(r){var n=this.__entries__,o=e(n,r);~o&&n.splice(o,1)},t.prototype.has=function(r){return!!~e(this.__entries__,r)},t.prototype.clear=function(){this.__entries__.splice(0)},t.prototype.forEach=function(r,n){n===void 0&&(n=null);for(var o=0,i=this.__entries__;o0},e.prototype.connect_=function(){!zr||this.connected_||(document.addEventListener("transitionend",this.onTransitionEnd_),window.addEventListener("resize",this.refresh),xa?(this.mutationsObserver_=new MutationObserver(this.refresh),this.mutationsObserver_.observe(document,{attributes:!0,childList:!0,characterData:!0,subtree:!0})):(document.addEventListener("DOMSubtreeModified",this.refresh),this.mutationEventsAdded_=!0),this.connected_=!0)},e.prototype.disconnect_=function(){!zr||!this.connected_||(document.removeEventListener("transitionend",this.onTransitionEnd_),window.removeEventListener("resize",this.refresh),this.mutationsObserver_&&this.mutationsObserver_.disconnect(),this.mutationEventsAdded_&&document.removeEventListener("DOMSubtreeModified",this.refresh),this.mutationsObserver_=null,this.mutationEventsAdded_=!1,this.connected_=!1)},e.prototype.onTransitionEnd_=function(t){var r=t.propertyName,n=r===void 0?"":r,o=ya.some(function(i){return!!~n.indexOf(i)});o&&this.refresh()},e.getInstance=function(){return this.instance_||(this.instance_=new e),this.instance_},e.instance_=null,e}(),Jn=function(e,t){for(var r=0,n=Object.keys(t);r0},e}(),Zn=typeof WeakMap!="undefined"?new WeakMap:new Bn,eo=function(){function e(t){if(!(this instanceof e))throw new TypeError("Cannot call a class as a function.");if(!arguments.length)throw new TypeError("1 argument required, but only 0 present.");var r=Ea.getInstance(),n=new Ra(t,r,this);Zn.set(this,n)}return e}();["observe","unobserve","disconnect"].forEach(function(e){eo.prototype[e]=function(){var t;return(t=Zn.get(this))[e].apply(t,arguments)}});var ka=function(){return typeof nr.ResizeObserver!="undefined"?nr.ResizeObserver:eo}(),to=ka;var ro=new E,Ha=I(()=>H(new to(e=>{for(let t of e)ro.next(t)}))).pipe(x(e=>L(Te,H(e)).pipe(C(()=>e.disconnect()))),J(1));function de(e){return{width:e.offsetWidth,height:e.offsetHeight}}function ge(e){return Ha.pipe(S(t=>t.observe(e)),x(t=>ro.pipe(_(({target:r})=>r===e),C(()=>t.unobserve(e)),l(()=>de(e)))),N(de(e)))}function bt(e){return{width:e.scrollWidth,height:e.scrollHeight}}function ar(e){let t=e.parentElement;for(;t&&(e.scrollWidth<=t.scrollWidth&&e.scrollHeight<=t.scrollHeight);)t=(e=t).parentElement;return t?e:void 0}var no=new E,Pa=I(()=>H(new IntersectionObserver(e=>{for(let t of e)no.next(t)},{threshold:0}))).pipe(x(e=>L(Te,H(e)).pipe(C(()=>e.disconnect()))),J(1));function sr(e){return Pa.pipe(S(t=>t.observe(e)),x(t=>no.pipe(_(({target:r})=>r===e),C(()=>t.unobserve(e)),l(({isIntersecting:r})=>r))))}function oo(e,t=16){return dt(e).pipe(l(({y:r})=>{let n=de(e),o=bt(e);return r>=o.height-n.height-t}),Y())}var cr={drawer:V("[data-md-toggle=drawer]"),search:V("[data-md-toggle=search]")};function io(e){return cr[e].checked}function qe(e,t){cr[e].checked!==t&&cr[e].click()}function je(e){let t=cr[e];return b(t,"change").pipe(l(()=>t.checked),N(t.checked))}function $a(e,t){switch(e.constructor){case HTMLInputElement:return e.type==="radio"?/^Arrow/.test(t):!0;case HTMLSelectElement:case HTMLTextAreaElement:return!0;default:return e.isContentEditable}}function Ia(){return L(b(window,"compositionstart").pipe(l(()=>!0)),b(window,"compositionend").pipe(l(()=>!1))).pipe(N(!1))}function ao(){let e=b(window,"keydown").pipe(_(t=>!(t.metaKey||t.ctrlKey)),l(t=>({mode:io("search")?"search":"global",type:t.key,claim(){t.preventDefault(),t.stopPropagation()}})),_(({mode:t,type:r})=>{if(t==="global"){let n=_e();if(typeof n!="undefined")return!$a(n,r)}return!0}),fe());return Ia().pipe(x(t=>t?R:e))}function Me(){return new URL(location.href)}function ot(e){location.href=e.href}function so(){return new E}function co(e,t){if(typeof t=="string"||typeof t=="number")e.innerHTML+=t.toString();else if(t instanceof Node)e.appendChild(t);else if(Array.isArray(t))for(let r of t)co(e,r)}function M(e,t,...r){let n=document.createElement(e);if(t)for(let o of Object.keys(t))typeof t[o]!="undefined"&&(typeof t[o]!="boolean"?n.setAttribute(o,t[o]):n.setAttribute(o,""));for(let o of r)co(n,o);return n}function fr(e){if(e>999){let t=+((e-950)%1e3>99);return`${((e+1e-6)/1e3).toFixed(t)}k`}else return e.toString()}function fo(){return location.hash.substring(1)}function uo(e){let t=M("a",{href:e});t.addEventListener("click",r=>r.stopPropagation()),t.click()}function Fa(){return b(window,"hashchange").pipe(l(fo),N(fo()),_(e=>e.length>0),J(1))}function po(){return Fa().pipe(l(e=>se(`[id="${e}"]`)),_(e=>typeof e!="undefined"))}function Nr(e){let t=matchMedia(e);return Zt(r=>t.addListener(()=>r(t.matches))).pipe(N(t.matches))}function lo(){let e=matchMedia("print");return L(b(window,"beforeprint").pipe(l(()=>!0)),b(window,"afterprint").pipe(l(()=>!1))).pipe(N(e.matches))}function qr(e,t){return e.pipe(x(r=>r?t():R))}function ur(e,t={credentials:"same-origin"}){return ve(fetch(`${e}`,t)).pipe(ce(()=>R),x(r=>r.status!==200?Tt(()=>new Error(r.statusText)):H(r)))}function Ue(e,t){return ur(e,t).pipe(x(r=>r.json()),J(1))}function mo(e,t){let r=new DOMParser;return ur(e,t).pipe(x(n=>n.text()),l(n=>r.parseFromString(n,"text/xml")),J(1))}function pr(e){let t=M("script",{src:e});return I(()=>(document.head.appendChild(t),L(b(t,"load"),b(t,"error").pipe(x(()=>Tt(()=>new ReferenceError(`Invalid script: ${e}`))))).pipe(l(()=>{}),C(()=>document.head.removeChild(t)),Oe(1))))}function ho(){return{x:Math.max(0,scrollX),y:Math.max(0,scrollY)}}function bo(){return L(b(window,"scroll",{passive:!0}),b(window,"resize",{passive:!0})).pipe(l(ho),N(ho()))}function vo(){return{width:innerWidth,height:innerHeight}}function go(){return b(window,"resize",{passive:!0}).pipe(l(vo),N(vo()))}function yo(){return Q([bo(),go()]).pipe(l(([e,t])=>({offset:e,size:t})),J(1))}function lr(e,{viewport$:t,header$:r}){let n=t.pipe(X("size")),o=Q([n,r]).pipe(l(()=>Be(e)));return Q([r,t,o]).pipe(l(([{height:i},{offset:a,size:s},{x:f,y:c}])=>({offset:{x:a.x-f,y:a.y-c+i},size:s})))}(()=>{function e(n,o){parent.postMessage(n,o||"*")}function t(...n){return n.reduce((o,i)=>o.then(()=>new Promise(a=>{let s=document.createElement("script");s.src=i,s.onload=a,document.body.appendChild(s)})),Promise.resolve())}var r=class{constructor(n){this.url=n,this.onerror=null,this.onmessage=null,this.onmessageerror=null,this.m=a=>{a.source===this.w&&(a.stopImmediatePropagation(),this.dispatchEvent(new MessageEvent("message",{data:a.data})),this.onmessage&&this.onmessage(a))},this.e=(a,s,f,c,u)=>{if(s===this.url.toString()){let p=new ErrorEvent("error",{message:a,filename:s,lineno:f,colno:c,error:u});this.dispatchEvent(p),this.onerror&&this.onerror(p)}};let o=new EventTarget;this.addEventListener=o.addEventListener.bind(o),this.removeEventListener=o.removeEventListener.bind(o),this.dispatchEvent=o.dispatchEvent.bind(o);let i=document.createElement("iframe");i.width=i.height=i.frameBorder="0",document.body.appendChild(this.iframe=i),this.w.document.open(),this.w.document.write(` + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + +
+ + +
+ +
+ + + + + + +
+
+ + + +
+
+
+ + + + +
+
+
+ + + +
+
+
+ + + +
+
+
+ + + +
+
+ + + + + + + + +

Sending API requests to Flow Launcher

+

You can send special requests to Flow Launcher to control the launcher from your plugin. This communication is currently only one way.

+
+

Warning

+

You can not send API requests from a query or context_menu method!

+

Using API requests in this way will cause your plugin to fail!

+
+

Sending a command from a Result

+
from pyflowlauncher import Plugin, Result, send_results, api
+from pyflowlauncher.result import ResultResponse
+
+plugin = Plugin()
+
+
+@plugin.on_method
+def query(query: str) -> ResultResponse:
+    r = Result(
+        Title="This is a title!",
+        SubTitle="This is the subtitle!",
+        IcoPath="icon.png",
+        JsonRPCAction=api.change_query("This is a new query!"),
+    )
+    return send_results([r])
+
+
+plugin.run()
+
+

The example above will change the query in Flow Launcher when the user selects your result.

+

Sending a command from a Method

+

You can also send an API request in a custom method like so:

+
from pyflowlauncher import Plugin, Result, send_results, api
+from pyflowlauncher.result import JsonRPCAction, ResultResponse
+
+plugin = Plugin()
+
+
+@plugin.on_method
+def example_method() -> JsonRPCAction:
+    # Do stuff here
+    return api.change_query("This is also a new query!")
+
+
+@plugin.on_method
+def query(query: str) -> ResultResponse:
+    r = Result(
+        Title="This is a title!",
+        SubTitle="This is the subtitle!",
+        IcoPath="icon.png",
+    )
+    r.add_action(example_method)
+    return send_results([r])
+
+
+plugin.run()
+
+ + + + + + +
+
+ + +
+ +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/guide/Launcher_Icons/index.html b/guide/Launcher_Icons/index.html new file mode 100644 index 0000000..13fb9c4 --- /dev/null +++ b/guide/Launcher_Icons/index.html @@ -0,0 +1,562 @@ + + + + + + + + + + + + + + + + + + + + + + Using icons included with Flow Launcher - PyFlowLauncher + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + +
+ + +
+ +
+ + + + + + +
+
+ + + +
+
+
+ + + + +
+
+
+ + + +
+
+
+ + + +
+
+
+ + + +
+
+ + + + + + + + +

Using icons included with Flow Launcher

+

Flow Launcher comes with a decent amount of icons that it uses throughout it's UI and plugins.

+

You can use some of these icons in your plugin by importing from the icons module.

+
+

Warning

+

If PyFlowLauncher is unable to locate the Flow Launcher directory these icons may not be loaded!

+

This will not crash your plugin but will leave the icon blank.

+
+

Example

+
from pyflowlauncher import Plugin, Result, send_results
+from pyflowlauncher.result import ResultResponse
+from pyflowlauncher.icons import ADMIN
+
+plugin = Plugin()
+
+
+@plugin.on_method
+def query(query: str) -> ResultResponse:
+    r = Result(
+        Title="This is a title!",
+        SubTitle="This is the subtitle!",
+        IcoPath=ADMIN
+    )
+    return send_results([r])
+
+
+plugin.run()
+
+ + + + + + +
+
+ + +
+ +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/guide/Plugin methods/index.html b/guide/Plugin methods/index.html new file mode 100644 index 0000000..8f1a44f --- /dev/null +++ b/guide/Plugin methods/index.html @@ -0,0 +1,603 @@ + + + + + + + + + + + + + + + + + + + + + + Triggering Plugin methods - PyFlowLauncher + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + +
+ + +
+ +
+ + + + + + +
+
+ + + +
+
+
+ + + + +
+
+
+ + + +
+
+
+ + + +
+
+
+ + + +
+
+ + + + + + + + +

Triggering Plugin methods

+

Flow Launcher can call custom methods created by your plugin as well. To do so simply register the method with your plugin.

+

You can register any Function by using the on_method decorator or by using the add_method method from Plugin.

+

Example 1

+
from pyflowlauncher import Plugin, Result, send_results
+from pyflowlauncher.result import ResultResponse
+
+plugin = Plugin()
+
+
+@plugin.on_method
+def query(query: str) -> ResultResponse:
+    r = Result(
+        Title="This is a title!",
+        SubTitle="This is the subtitle!",
+        JsonRPCAction={"method": "action", "parameters": []}
+    )
+    return send_results([r])
+
+
+@plugin.on_method
+def action(params: list[str]):
+    pass
+    # Do stuff here
+    # ...
+
+
+plugin.run()
+
+

Alternativley you can register and add the Method to a Result in one line by using action method.

+

Example 2

+
from pyflowlauncher import Plugin, Result, send_results
+from pyflowlauncher.result import ResultResponse
+
+plugin = Plugin()
+
+
+@plugin.on_method
+def query(query: str) -> ResultResponse:
+    r = Result(
+        Title="This is a title!",
+        SubTitle="This is the subtitle!",
+        JsonRPCAction=plugin.action(action, ["stuff"])
+    )
+    return send_results([r])
+
+
+def action(params: list[str]):
+    pass
+    # Do stuff here
+    # ...
+
+
+plugin.run()
+
+ + + + + + +
+
+ + +
+ +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/guide/scoring_results/index.html b/guide/scoring_results/index.html new file mode 100644 index 0000000..00a5832 --- /dev/null +++ b/guide/scoring_results/index.html @@ -0,0 +1,558 @@ + + + + + + + + + + + + + + + + + + + + + + Score results - PyFlowLauncher + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + +
+ + +
+ +
+ + + + + + +
+
+ + + +
+
+
+ + + + +
+
+
+ + + +
+
+
+ + + +
+
+
+ + + +
+
+ + + + + + + + +

Score results

+

PyFlowLauncher comes with a handy utility to help score your results in a similar manner to how Flow Launcher does internally.

+

Example

+
from pyflowlauncher import Plugin, Result, send_results
+from pyflowlauncher.result import ResultResponse
+from pyflowlauncher.utils import score_results
+
+plugin = Plugin()
+
+
+@plugin.on_method
+def query(query: str) -> ResultResponse:
+    results = []
+    for _ in range(100):
+        r = Result(
+            Title="This is a title!",
+            SubTitle="This is the subtitle!",
+        )
+        results.append(r)
+    return send_results(score_results(query, results))
+
+
+plugin.run()
+
+ + + + + + +
+
+ + +
+ +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/index.html b/index.html new file mode 100644 index 0000000..80d8879 --- /dev/null +++ b/index.html @@ -0,0 +1,543 @@ + + + + + + + + + + + + + + + + + + + + PyFlowLauncher + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + +
+ + +
+ +
+ + + + + + +
+
+ + + +
+
+
+ + + + +
+
+
+ + + +
+
+
+ + + +
+
+
+ + + +
+
+ + + + + + + + +

Home

+

Tests Workflow Status +Docs Workflow Status +Release Workflow Status +pypi +GitHub License +buymeacoffee

+

pyFlowLauncher

+

pyFlowLauncher is an API that allows you to quickly create plugins for Flow Launcher!

+

Installation

+

Install via pip:

+
python -m pip install pyflowlauncher[all]
+
+
+

[!IMPORTANT] +Please use the [all] flag in order to support Python versions older then 3.11.

+
+

Usage

+

Basic plugin

+

A basic plugin using a function as the query method.

+
from pyflowlauncher import Plugin, Result, send_results
+from pyflowlauncher.result import ResultResponse
+
+plugin = Plugin()
+
+
+@plugin.on_method
+def query(query: str) -> ResultResponse:
+    r = Result(
+        Title="This is a title!",
+        SubTitle="This is the subtitle!",
+        IcoPath="icon.png"
+    )
+    return send_results([r])
+
+
+plugin.run()
+
+

Advanced plugin

+

A more advanced usage using a Method class as the query method.

+
from pyflowlauncher import Plugin, Result, Method
+from pyflowlauncher.result import ResultResponse
+
+plugin = Plugin()
+
+
+class Query(Method):
+
+    def __call__(self, query: str) -> ResultResponse:
+        r = Result(
+            Title="This is a title!",
+            SubTitle="This is the subtitle!"
+        )
+        self.add_result(r)
+        return self.return_results()
+
+plugin.add_method(Query())
+plugin.run()
+
+ + + + + + +
+
+ + +
+ +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/objects.inv b/objects.inv new file mode 100644 index 0000000000000000000000000000000000000000..9a010726b338f855aa72f41ad6bff4e230090daf GIT binary patch literal 788 zcmV+v1MB=FAX9K?X>NERX>N99Zgg*Qc_4OWa&u{KZXhxWBOp+6Z)#;@bUGkVc}8q+ zcT8b*ZewU=atb3LR%LQ?X>V>iATTa4E-(rsAXI2&AaZ4GVQFq;WpW^IW*~HEX>%ZE zX>4U6X>%ZBZ*6dLWpi_7WFU2OX>MmAdTeQ8E(&f_S>VG&qhNL z6qCx1$QTnmmXfv3;Z98%75dV+lng!v*qUMa zanAkF1%w=B-<~Ic=LhK3qVA90ThX^m&{^V#V=U3RtBiNCH%dsbd^%QeqgLQU4^mIl zi_5+(Krd8ZSvkZ|AI3dMrRfFPXTw8qG-THp_Yuhhl!A_($h)V6n4Z^U~-8rHyAp#yLZx%IhIC(jB`uOW+Bi) zB2g~iRnUn_4@BLI-Do|#TRtA?A|ykXkD5}HY_aPSM$H46q~$u8#}0yEc`%Y~-+Rhp SwZ?aU^mRr&J^Ta0-m8j;Pj)H* literal 0 HcmV?d00001 diff --git a/reference/api/index.html b/reference/api/index.html new file mode 100644 index 0000000..088d936 --- /dev/null +++ b/reference/api/index.html @@ -0,0 +1,1280 @@ + + + + + + + + + + + + + + + + + + + + + + API Reference - PyFlowLauncher + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + +
+ + +
+ +
+ + + + + + +
+
+ + + +
+
+
+ + + + +
+
+
+ + + +
+
+
+ + + +
+
+
+ + + +
+
+ + + + + + + + +

API Reference

+ + +
+ + + + +
+ + + +
+ + + + + +

Attributes

+ +
+ + + +

+ NAME_SPACE + + + + module-attribute + + +

+
NAME_SPACE = 'Flow.Launcher'
+
+ +
+
+ +
+

Classes

+

Functions

+ + +
+ + + +

+ change_query + + +

+
change_query(query: str, requery: bool = False) -> JsonRPCAction
+
+ +
+ +

Change the query in Flow Launcher.

+ +
+ Source code in pyflowlauncher/api.py +
12
+13
+14
def change_query(query: str, requery: bool = False) -> JsonRPCAction:
+    """Change the query in Flow Launcher."""
+    return _send_action("ChangeQuery", query, requery)
+
+
+
+ +
+ + +
+ + + +

+ close_app + + +

+
close_app() -> JsonRPCAction
+
+ +
+ +

Close Flow Launcher.

+ +
+ Source code in pyflowlauncher/api.py +
22
+23
+24
def close_app() -> JsonRPCAction:
+    """Close Flow Launcher."""
+    return _send_action("CloseApp")
+
+
+
+ +
+ + +
+ + + +

+ copy_to_clipboard + + +

+
copy_to_clipboard(text: str, direct_copy: bool = False, show_default_notification=True) -> JsonRPCAction
+
+ +
+ +

Copy text to the clipboard.

+ +
+ Source code in pyflowlauncher/api.py +
62
+63
+64
def copy_to_clipboard(text: str, direct_copy: bool = False, show_default_notification=True) -> JsonRPCAction:
+    """Copy text to the clipboard."""
+    return _send_action("CopyToClipboard", text, direct_copy, show_default_notification)
+
+
+
+ +
+ + +
+ + + +

+ hide_app + + +

+
hide_app() -> JsonRPCAction
+
+ +
+ +

Hide Flow Launcher.

+ +
+ Source code in pyflowlauncher/api.py +
27
+28
+29
def hide_app() -> JsonRPCAction:
+    """Hide Flow Launcher."""
+    return _send_action("HideApp")
+
+
+
+ +
+ + +
+ + + +

+ open_directory + + +

+
open_directory(directory_path: str, filename_or_filepath: Optional[str] = None) -> JsonRPCAction
+
+ +
+ +

Open a directory.

+ +
+ Source code in pyflowlauncher/api.py +
67
+68
+69
def open_directory(directory_path: str, filename_or_filepath: Optional[str] = None) -> JsonRPCAction:
+    """Open a directory."""
+    return _send_action("OpenDirectory", directory_path, filename_or_filepath)
+
+
+
+ +
+ + +
+ + + +

+ open_setting_dialog + + +

+
open_setting_dialog() -> JsonRPCAction
+
+ +
+ +

Open the settings window in Flow Launcher.

+ +
+ Source code in pyflowlauncher/api.py +
42
+43
+44
def open_setting_dialog() -> JsonRPCAction:
+    """Open the settings window in Flow Launcher."""
+    return _send_action("OpenSettingDialog")
+
+
+
+ +
+ + +
+ + + +

+ open_uri + + +

+
open_uri(uri: str) -> JsonRPCAction
+
+ +
+ +

Open a URI.

+ +
+ Source code in pyflowlauncher/api.py +
77
+78
+79
def open_uri(uri: str) -> JsonRPCAction:
+    """Open a URI."""
+    return _send_action("OpenAppUri", uri)
+
+
+
+ +
+ + +
+ + + +

+ open_url + + +

+
open_url(url: str, in_private: bool = False) -> JsonRPCAction
+
+ +
+ +

Open a URL.

+ +
+ Source code in pyflowlauncher/api.py +
72
+73
+74
def open_url(url: str, in_private: bool = False) -> JsonRPCAction:
+    """Open a URL."""
+    return _send_action("OpenUrl", url, in_private)
+
+
+
+ +
+ + +
+ + + +

+ reload_plugins + + +

+
reload_plugins() -> JsonRPCAction
+
+ +
+ +

Reload the plugins in Flow Launcher.

+ +
+ Source code in pyflowlauncher/api.py +
57
+58
+59
def reload_plugins() -> JsonRPCAction:
+    """Reload the plugins in Flow Launcher."""
+    return _send_action("ReloadPlugins")
+
+
+
+ +
+ + +
+ + + +

+ shell_run + + +

+
shell_run(command: str, filename: str = 'cmd.exe') -> JsonRPCAction
+
+ +
+ +

Run a shell command.

+ +
+ Source code in pyflowlauncher/api.py +
17
+18
+19
def shell_run(command: str, filename: str = 'cmd.exe') -> JsonRPCAction:
+    """Run a shell command."""
+    return _send_action("ShellRun", command, filename)
+
+
+
+ +
+ + +
+ + + +

+ show_app + + +

+
show_app() -> JsonRPCAction
+
+ +
+ +

Show Flow Launcher.

+ +
+ Source code in pyflowlauncher/api.py +
32
+33
+34
def show_app() -> JsonRPCAction:
+    """Show Flow Launcher."""
+    return _send_action("ShowApp")
+
+
+
+ +
+ + +
+ + + +

+ show_msg + + +

+
show_msg(title: str, sub_title: str, ico_path: str = '') -> JsonRPCAction
+
+ +
+ +

Show a message in Flow Launcher.

+ +
+ Source code in pyflowlauncher/api.py +
37
+38
+39
def show_msg(title: str, sub_title: str, ico_path: str = "") -> JsonRPCAction:
+    """Show a message in Flow Launcher."""
+    return _send_action("ShowMsg", title, sub_title, ico_path)
+
+
+
+ +
+ + +
+ + + +

+ start_loading_bar + + +

+
start_loading_bar() -> JsonRPCAction
+
+ +
+ +

Start the loading bar in Flow Launcher.

+ +
+ Source code in pyflowlauncher/api.py +
47
+48
+49
def start_loading_bar() -> JsonRPCAction:
+    """Start the loading bar in Flow Launcher."""
+    return _send_action("StartLoadingBar")
+
+
+
+ +
+ + +
+ + + +

+ stop_loading_bar + + +

+
stop_loading_bar() -> JsonRPCAction
+
+ +
+ +

Stop the loading bar in Flow Launcher.

+ +
+ Source code in pyflowlauncher/api.py +
52
+53
+54
def stop_loading_bar() -> JsonRPCAction:
+    """Stop the loading bar in Flow Launcher."""
+    return _send_action("StopLoadingBar")
+
+
+
+ +
+ + + +
+ +
+ +
+ + + + + + +
+
+ + +
+ +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/reference/event/index.html b/reference/event/index.html new file mode 100644 index 0000000..475207e --- /dev/null +++ b/reference/event/index.html @@ -0,0 +1,961 @@ + + + + + + + + + + + + + + + + + + + + + + event - PyFlowLauncher + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + +
+ + +
+ +
+ + + + + + +
+
+ + + +
+
+
+ + + + +
+
+
+ + + +
+
+
+ + + +
+
+
+ + + +
+
+ + + + + + + + +

event

+ + +
+ + + + +
+ + + +
+ + + + + + +

Classes

+ +
+ + + +

+ EventHandler + + +

+ + +
+ + +
+ Source code in pyflowlauncher/event.py +
 6
+ 7
+ 8
+ 9
+10
+11
+12
+13
+14
+15
+16
+17
+18
+19
+20
+21
+22
+23
+24
+25
+26
+27
+28
+29
+30
+31
+32
+33
+34
class EventHandler:
+
+    def __init__(self):
+        self._methods = {}
+        self._handlers = {}
+
+    def _get_callable_name(self, method: Callable[..., Any]):
+        return getattr(method, '__name__', method.__class__.__name__).lower()
+
+    def add_method(self, method: Callable[..., Any], *, name=None) -> str:
+        key = name or self._get_callable_name(method)
+        self._methods[key] = method
+        return key
+
+    def add_methods(self, methods: Iterable[Callable[..., Any]]):
+        for method in methods:
+            self.add_method(method)
+
+    def add_exception_handler(self, exception: Type[Exception], handler: Callable[..., Any]):
+        self._handlers[exception] = handler
+
+    def __call__(self, method: str, *args, **kwargs):
+        try:
+            return self._methods[method](*args, **kwargs)
+        except Exception as e:
+            handler = self._handlers.get(type(e), None)
+            if handler:
+                return handler(e)
+            raise e
+
+
+ + + +
+ + + + + + + +

Functions

+ + +
+ + + +
+ __call__ + + +
+
__call__(method: str, *args, **kwargs)
+
+ +
+ +
+ Source code in pyflowlauncher/event.py +
27
+28
+29
+30
+31
+32
+33
+34
def __call__(self, method: str, *args, **kwargs):
+    try:
+        return self._methods[method](*args, **kwargs)
+    except Exception as e:
+        handler = self._handlers.get(type(e), None)
+        if handler:
+            return handler(e)
+        raise e
+
+
+
+ +
+ + +
+ + + +
+ __init__ + + +
+
__init__()
+
+ +
+ +
+ Source code in pyflowlauncher/event.py +
 8
+ 9
+10
def __init__(self):
+    self._methods = {}
+    self._handlers = {}
+
+
+
+ +
+ + +
+ + + +
+ add_exception_handler + + +
+
add_exception_handler(exception: Type[Exception], handler: Callable[..., Any])
+
+ +
+ +
+ Source code in pyflowlauncher/event.py +
24
+25
def add_exception_handler(self, exception: Type[Exception], handler: Callable[..., Any]):
+    self._handlers[exception] = handler
+
+
+
+ +
+ + +
+ + + +
+ add_method + + +
+
add_method(method: Callable[..., Any], *, name=None) -> str
+
+ +
+ +
+ Source code in pyflowlauncher/event.py +
15
+16
+17
+18
def add_method(self, method: Callable[..., Any], *, name=None) -> str:
+    key = name or self._get_callable_name(method)
+    self._methods[key] = method
+    return key
+
+
+
+ +
+ + +
+ + + +
+ add_methods + + +
+
add_methods(methods: Iterable[Callable[..., Any]])
+
+ +
+ +
+ Source code in pyflowlauncher/event.py +
20
+21
+22
def add_methods(self, methods: Iterable[Callable[..., Any]]):
+    for method in methods:
+        self.add_method(method)
+
+
+
+ +
+ + + +
+ +
+ + +
+ + + + +
+ +
+ +

handler: python +options: +separate_signature: true +show_signature_annotations: true

+ + + + + + +
+
+ + +
+ +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/reference/plugin/index.html b/reference/plugin/index.html new file mode 100644 index 0000000..e49b0e2 --- /dev/null +++ b/reference/plugin/index.html @@ -0,0 +1,1369 @@ + + + + + + + + + + + + + + + + + + + + + + Plugin Reference - PyFlowLauncher + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + +
+ + +
+ +
+ + + + + + +
+
+ + + +
+
+
+ + + + +
+
+
+ + + +
+
+
+ + + +
+
+
+ + + +
+
+ + + + + + + + +

Plugin Reference

+ + +
+ + + + +
+ + +
+ Source code in pyflowlauncher/plugin.py +
19
+20
+21
+22
+23
+24
+25
+26
+27
+28
+29
+30
+31
+32
+33
+34
+35
+36
+37
+38
+39
+40
+41
+42
+43
+44
+45
+46
+47
+48
+49
+50
+51
+52
+53
+54
+55
+56
+57
+58
+59
+60
+61
+62
+63
+64
+65
+66
+67
+68
+69
+70
+71
+72
+73
+74
+75
+76
+77
+78
+79
+80
+81
+82
+83
+84
+85
+86
+87
+88
+89
+90
+91
+92
+93
+94
+95
+96
+97
class Plugin:
+
+    def __init__(self, methods: list[Method] | None = None) -> None:
+        self._logger = logger(self)
+        self._client = JsonRPCClient()
+        self._event_handler = EventHandler()
+        self._settings: dict[str, Any] = {}
+        if methods:
+            self.add_methods(methods)
+
+    def add_method(self, method: Method) -> str:
+        """Add a method to the event handler."""
+        return self._event_handler.add_method(method)
+
+    def add_methods(self, methods: Iterable[Method]) -> None:
+        self._event_handler.add_methods(methods)
+
+    def on_method(self, method: Method) -> Method:
+        @wraps(method)
+        def wrapper(*args, **kwargs):
+            return method(*args, **kwargs)
+        self._event_handler.add_method(wrapper)
+        return wrapper
+
+    def method(self, method: Method) -> Method:
+        """Register a method to be called when the plugin is run."""
+        return self.on_method(method)
+
+    def add_exception_handler(self, exception: Type[Exception], handler: Callable[..., Any]) -> None:
+        """Add exception handler to be called when an exception is raised in a method."""
+        self._event_handler.add_exception_handler(exception, handler)
+
+    def on_except(self, exception: Type[Exception]) -> Callable[..., Any]:
+        @wraps(exception)
+        def wrapper(handler: Callable[..., Any]) -> Callable[..., Any]:
+            self.add_exception_handler(exception, handler)
+            return handler
+        return wrapper
+
+    def action(self, method: Method, parameters: Optional[Iterable] = None) -> JsonRPCAction:
+        """Register a method and return a JsonRPCAction that calls it."""
+        method_name = self.add_method(method)
+        return {"method": method_name, "parameters": parameters or []}
+
+    @property
+    def settings(self) -> dict:
+        if self._settings is None:
+            self._settings = {}
+        self._settings = self._client.recieve().get('settings', {})
+        return self._settings
+
+    def run(self) -> None:
+        request = self._client.recieve()
+        method = request["method"]
+        parameters = request.get('parameters', [])
+        feedback = self._event_handler(method, *parameters)
+        if not feedback:
+            return
+        self._client.send(feedback)
+
+    @property
+    def run_dir(self) -> Path:
+        """Return the run directory of the plugin."""
+        return Path(sys.argv[0]).parent
+
+    def root_dir(self) -> Path:
+        """Return the root directory of the plugin."""
+        current_dir = self.run_dir
+        for part in current_dir.parts:
+            if current_dir.joinpath(MANIFEST_FILE).exists():
+                return current_dir
+            current_dir = current_dir.parent
+        raise FileNotFoundError(f"Could not find {MANIFEST_FILE} in {self.run_dir} or any parent directory.")
+
+    def manifest(self) -> PluginManifestSchema:
+        """Return the plugin manifest."""
+        with open(self.root_dir() / MANIFEST_FILE, 'r', encoding='utf-8') as f:
+            manifest = json.load(f)
+        return manifest
+
+
+ + + +
+ + + + + +

Attributes

+ +
+ + + +

+ run_dir + + + + property + + +

+
run_dir: Path
+
+ +
+ +

Return the run directory of the plugin.

+
+ +
+ +
+ + + +

+ settings + + + + property + + +

+
settings: dict
+
+ +
+
+ +
+ +

Functions

+ + +
+ + + +

+ __init__ + + +

+
__init__(methods: list[Method] | None = None) -> None
+
+ +
+ +
+ Source code in pyflowlauncher/plugin.py +
21
+22
+23
+24
+25
+26
+27
def __init__(self, methods: list[Method] | None = None) -> None:
+    self._logger = logger(self)
+    self._client = JsonRPCClient()
+    self._event_handler = EventHandler()
+    self._settings: dict[str, Any] = {}
+    if methods:
+        self.add_methods(methods)
+
+
+
+ +
+ + +
+ + + +

+ action + + +

+
action(method: Method, parameters: Optional[Iterable] = None) -> JsonRPCAction
+
+ +
+ +

Register a method and return a JsonRPCAction that calls it.

+ +
+ Source code in pyflowlauncher/plugin.py +
58
+59
+60
+61
def action(self, method: Method, parameters: Optional[Iterable] = None) -> JsonRPCAction:
+    """Register a method and return a JsonRPCAction that calls it."""
+    method_name = self.add_method(method)
+    return {"method": method_name, "parameters": parameters or []}
+
+
+
+ +
+ + +
+ + + +

+ add_exception_handler + + +

+
add_exception_handler(exception: Type[Exception], handler: Callable[..., Any]) -> None
+
+ +
+ +

Add exception handler to be called when an exception is raised in a method.

+ +
+ Source code in pyflowlauncher/plugin.py +
47
+48
+49
def add_exception_handler(self, exception: Type[Exception], handler: Callable[..., Any]) -> None:
+    """Add exception handler to be called when an exception is raised in a method."""
+    self._event_handler.add_exception_handler(exception, handler)
+
+
+
+ +
+ + +
+ + + +

+ add_method + + +

+
add_method(method: Method) -> str
+
+ +
+ +

Add a method to the event handler.

+ +
+ Source code in pyflowlauncher/plugin.py +
29
+30
+31
def add_method(self, method: Method) -> str:
+    """Add a method to the event handler."""
+    return self._event_handler.add_method(method)
+
+
+
+ +
+ + +
+ + + +

+ add_methods + + +

+
add_methods(methods: Iterable[Method]) -> None
+
+ +
+ +
+ Source code in pyflowlauncher/plugin.py +
33
+34
def add_methods(self, methods: Iterable[Method]) -> None:
+    self._event_handler.add_methods(methods)
+
+
+
+ +
+ + +
+ + + +

+ manifest + + +

+
manifest() -> PluginManifestSchema
+
+ +
+ +

Return the plugin manifest.

+ +
+ Source code in pyflowlauncher/plugin.py +
93
+94
+95
+96
+97
def manifest(self) -> PluginManifestSchema:
+    """Return the plugin manifest."""
+    with open(self.root_dir() / MANIFEST_FILE, 'r', encoding='utf-8') as f:
+        manifest = json.load(f)
+    return manifest
+
+
+
+ +
+ + +
+ + + +

+ method + + +

+
method(method: Method) -> Method
+
+ +
+ +

Register a method to be called when the plugin is run.

+ +
+ Source code in pyflowlauncher/plugin.py +
43
+44
+45
def method(self, method: Method) -> Method:
+    """Register a method to be called when the plugin is run."""
+    return self.on_method(method)
+
+
+
+ +
+ + +
+ + + +

+ on_except + + +

+
on_except(exception: Type[Exception]) -> Callable[..., Any]
+
+ +
+ +
+ Source code in pyflowlauncher/plugin.py +
51
+52
+53
+54
+55
+56
def on_except(self, exception: Type[Exception]) -> Callable[..., Any]:
+    @wraps(exception)
+    def wrapper(handler: Callable[..., Any]) -> Callable[..., Any]:
+        self.add_exception_handler(exception, handler)
+        return handler
+    return wrapper
+
+
+
+ +
+ + +
+ + + +

+ on_method + + +

+
on_method(method: Method) -> Method
+
+ +
+ +
+ Source code in pyflowlauncher/plugin.py +
36
+37
+38
+39
+40
+41
def on_method(self, method: Method) -> Method:
+    @wraps(method)
+    def wrapper(*args, **kwargs):
+        return method(*args, **kwargs)
+    self._event_handler.add_method(wrapper)
+    return wrapper
+
+
+
+ +
+ + +
+ + + +

+ root_dir + + +

+
root_dir() -> Path
+
+ +
+ +

Return the root directory of the plugin.

+ +
+ Source code in pyflowlauncher/plugin.py +
84
+85
+86
+87
+88
+89
+90
+91
def root_dir(self) -> Path:
+    """Return the root directory of the plugin."""
+    current_dir = self.run_dir
+    for part in current_dir.parts:
+        if current_dir.joinpath(MANIFEST_FILE).exists():
+            return current_dir
+        current_dir = current_dir.parent
+    raise FileNotFoundError(f"Could not find {MANIFEST_FILE} in {self.run_dir} or any parent directory.")
+
+
+
+ +
+ + +
+ + + +

+ run + + +

+
run() -> None
+
+ +
+ +
+ Source code in pyflowlauncher/plugin.py +
70
+71
+72
+73
+74
+75
+76
+77
def run(self) -> None:
+    request = self._client.recieve()
+    method = request["method"]
+    parameters = request.get('parameters', [])
+    feedback = self._event_handler(method, *parameters)
+    if not feedback:
+        return
+    self._client.send(feedback)
+
+
+
+ +
+ + + +
+ +
+ + +
+ + + + + + +
+
+ + +
+ +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/reference/result/index.html b/reference/result/index.html new file mode 100644 index 0000000..c2095a1 --- /dev/null +++ b/reference/result/index.html @@ -0,0 +1,2132 @@ + + + + + + + + + + + + + + + + + + + + result - PyFlowLauncher + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + +
+ + +
+ +
+ + + + + + +
+
+ + + +
+
+
+ + + + +
+
+
+ + + +
+
+
+ + + +
+
+
+ + + +
+
+ + + + + + + + +

result

+ + +
+ + + + +
+ + + +
+ + + + + +

Attributes

+

Classes

+ +
+ + + +

+ Glyph + + +

+ + +
+

+ Bases: TypedDict

+ + +

Flow Launcher Glyph

+ +
+ Source code in pyflowlauncher/result.py +
25
+26
+27
+28
class Glyph(TypedDict):
+    """Flow Launcher Glyph"""
+    Glyph: str
+    FontFamily: str
+
+
+ + + +
+ + + + + +

Attributes

+ +
+ + + +
+ FontFamily + + + + instance-attribute + + +
+
FontFamily: str
+
+ +
+
+ +
+ +
+ + + +
+ Glyph + + + + instance-attribute + + +
+
Glyph: str
+
+ +
+
+ +
+ + + + + +
+ +
+ + +
+ +
+ + + +

+ JsonRPCAction + + +

+ + +
+

+ Bases: TypedDict

+ + +

Flow Launcher JsonRPCAction

+ +
+ Source code in pyflowlauncher/result.py +
18
+19
+20
+21
+22
class JsonRPCAction(TypedDict):
+    """Flow Launcher JsonRPCAction"""
+    method: str
+    parameters: Iterable
+    dontHideAfterAction: NotRequired[bool]
+
+
+ + + +
+ + + + + +

Attributes

+ +
+ + + +
+ dontHideAfterAction + + + + instance-attribute + + +
+
dontHideAfterAction: NotRequired[bool]
+
+ +
+
+ +
+ +
+ + + +
+ method + + + + instance-attribute + + +
+
method: str
+
+ +
+
+ +
+ +
+ + + +
+ parameters + + + + instance-attribute + + +
+
parameters: Iterable
+
+ +
+
+ +
+ + + + + +
+ +
+ + +
+ +
+ + + +

+ PreviewInfo + + +

+ + +
+

+ Bases: TypedDict

+ + +

Flow Launcher Preview section

+ +
+ Source code in pyflowlauncher/result.py +
31
+32
+33
+34
+35
+36
class PreviewInfo(TypedDict):
+    """Flow Launcher Preview section"""
+    PreviewImagePath: Optional[str]
+    Description: Optional[str]
+    IsMedia: bool
+    PreviewDeligate: Optional[str]
+
+
+ + + +
+ + + + + +

Attributes

+ +
+ + + +
+ Description + + + + instance-attribute + + +
+
Description: Optional[str]
+
+ +
+
+ +
+ +
+ + + +
+ IsMedia + + + + instance-attribute + + +
+
IsMedia: bool
+
+ +
+
+ +
+ +
+ + + +
+ PreviewDeligate + + + + instance-attribute + + +
+
PreviewDeligate: Optional[str]
+
+ +
+
+ +
+ +
+ + + +
+ PreviewImagePath + + + + instance-attribute + + +
+
PreviewImagePath: Optional[str]
+
+ +
+
+ +
+ + + + + +
+ +
+ + +
+ +
+ + + +

+ Result + + + + dataclass + + +

+ + +
+ + +
+ Source code in pyflowlauncher/result.py +
39
+40
+41
+42
+43
+44
+45
+46
+47
+48
+49
+50
+51
+52
+53
+54
+55
+56
+57
+58
+59
+60
+61
+62
+63
+64
@dataclass
+class Result:
+    Title: str
+    SubTitle: Optional[str] = None
+    IcoPath: Optional[Union[str, Path]] = None
+    Score: int = 0
+    JsonRPCAction: Optional[JsonRPCAction] = None
+    ContextData: Optional[Iterable] = None
+    Glyph: Optional[Glyph] = None
+    CopyText: Optional[str] = None
+    AutoCompleteText: Optional[str] = None
+    RoundedIcon: bool = False
+    Preview: Optional[PreviewInfo] = None
+
+    def as_dict(self) -> Dict[str, Any]:
+        return self.__dict__
+
+    def add_action(self, method: Method,
+                   parameters: Optional[Iterable[Any]] = None,
+                   *,
+                   dont_hide_after_action: bool = False) -> None:
+        self.JsonRPCAction = {
+            "method": method.__name__,
+            "parameters": parameters or [],
+            "dontHideAfterAction": dont_hide_after_action
+        }
+
+
+ + + +
+ + + + + +

Attributes

+ +
+ + + +
+ AutoCompleteText + + + + class-attribute + instance-attribute + + +
+
AutoCompleteText: Optional[str] = None
+
+ +
+
+ +
+ +
+ + + +
+ ContextData + + + + class-attribute + instance-attribute + + +
+
ContextData: Optional[Iterable] = None
+
+ +
+
+ +
+ +
+ + + +
+ CopyText + + + + class-attribute + instance-attribute + + +
+
CopyText: Optional[str] = None
+
+ +
+
+ +
+ +
+ + + +
+ Glyph + + + + class-attribute + instance-attribute + + +
+
Glyph: Optional[Glyph] = None
+
+ +
+
+ +
+ +
+ + + +
+ IcoPath + + + + class-attribute + instance-attribute + + +
+
IcoPath: Optional[Union[str, Path]] = None
+
+ +
+
+ +
+ +
+ + + +
+ JsonRPCAction + + + + class-attribute + instance-attribute + + +
+
JsonRPCAction: Optional[JsonRPCAction] = None
+
+ +
+
+ +
+ +
+ + + +
+ Preview + + + + class-attribute + instance-attribute + + +
+
Preview: Optional[PreviewInfo] = None
+
+ +
+
+ +
+ +
+ + + +
+ RoundedIcon + + + + class-attribute + instance-attribute + + +
+
RoundedIcon: bool = False
+
+ +
+
+ +
+ +
+ + + +
+ Score + + + + class-attribute + instance-attribute + + +
+
Score: int = 0
+
+ +
+
+ +
+ +
+ + + +
+ SubTitle + + + + class-attribute + instance-attribute + + +
+
SubTitle: Optional[str] = None
+
+ +
+
+ +
+ +
+ + + +
+ Title + + + + instance-attribute + + +
+
Title: str
+
+ +
+
+ +
+ +

Functions

+ + +
+ + + +
+ add_action + + +
+
add_action(method: Method, parameters: Optional[Iterable[Any]] = None, *, dont_hide_after_action: bool = False) -> None
+
+ +
+ +
+ Source code in pyflowlauncher/result.py +
56
+57
+58
+59
+60
+61
+62
+63
+64
def add_action(self, method: Method,
+               parameters: Optional[Iterable[Any]] = None,
+               *,
+               dont_hide_after_action: bool = False) -> None:
+    self.JsonRPCAction = {
+        "method": method.__name__,
+        "parameters": parameters or [],
+        "dontHideAfterAction": dont_hide_after_action
+    }
+
+
+
+ +
+ + +
+ + + +
+ as_dict + + +
+
as_dict() -> Dict[str, Any]
+
+ +
+ +
+ Source code in pyflowlauncher/result.py +
53
+54
def as_dict(self) -> Dict[str, Any]:
+    return self.__dict__
+
+
+
+ +
+ + + +
+ +
+ + +
+ +
+ + + +

+ ResultResponse + + +

+ + +
+

+ Bases: TypedDict

+ + +
+ Source code in pyflowlauncher/result.py +
67
+68
+69
class ResultResponse(TypedDict):
+    result: List[Dict[str, Any]]
+    SettingsChange: NotRequired[Optional[Dict[str, Any]]]
+
+
+ + + +
+ + + + + +

Attributes

+ +
+ + + +
+ SettingsChange + + + + instance-attribute + + +
+
SettingsChange: NotRequired[Optional[Dict[str, Any]]]
+
+ +
+
+ +
+ +
+ + + +
+ result + + + + instance-attribute + + +
+
result: List[Dict[str, Any]]
+
+ +
+
+ +
+ + + + + +
+ +
+ + +
+

Functions

+ + +
+ + + +

+ send_results + + +

+
send_results(results: Iterable[Result], settings: Optional[Dict[str, Any]] = None) -> ResultResponse
+
+ +
+ +

Formats and returns results as a JsonRPCResponse

+ +
+ Source code in pyflowlauncher/result.py +
72
+73
+74
def send_results(results: Iterable[Result], settings: Optional[Dict[str, Any]] = None) -> ResultResponse:
+    """Formats and returns results as a JsonRPCResponse"""
+    return {'result': [result.as_dict() for result in results], 'SettingsChange': settings}
+
+
+
+ +
+ + + +
+ +
+ +
+ + + + + + +
+
+ + +
+ +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/sitemap.xml b/sitemap.xml new file mode 100644 index 0000000..b58580f --- /dev/null +++ b/sitemap.xml @@ -0,0 +1,48 @@ + + + + None + 2024-01-31 + daily + + + None + 2024-01-31 + daily + + + None + 2024-01-31 + daily + + + None + 2024-01-31 + daily + + + None + 2024-01-31 + daily + + + None + 2024-01-31 + daily + + + None + 2024-01-31 + daily + + + None + 2024-01-31 + daily + + + None + 2024-01-31 + daily + + \ No newline at end of file diff --git a/sitemap.xml.gz b/sitemap.xml.gz new file mode 100644 index 0000000000000000000000000000000000000000..44ee7a934aa9c084e9d1878291f908c2d429ec86 GIT binary patch literal 203 zcmV;+05ty}iwFp6vASgf|8r?{Wo=<_E_iKh0PU1b4#FT1h4(!LVPA$;7iuWoxpbum zAQW4Y7Am0C+e?39dIrYP}FX zbhhF-&G#wI(p?rKi?@o&MwnXNoqF&}==Q^4<;+C*AvgF2-{AiZpIUrT{0pg^S-R2$ F000U#VG;lU literal 0 HcmV?d00001