Script 'mail_helper' called by obssrc
Hello community,
here is the log from the commit of package python-jupyter-docprovider for
openSUSE:Factory checked in at 2025-06-23 14:56:33
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:Factory/python-jupyter-docprovider (Old)
and /work/SRC/openSUSE:Factory/.python-jupyter-docprovider.new.7067 (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Package is "python-jupyter-docprovider"
Mon Jun 23 14:56:33 2025 rev:3 rq:1287606 version:2.0.2
Changes:
--------
---
/work/SRC/openSUSE:Factory/python-jupyter-docprovider/python-jupyter-docprovider.changes
2025-01-31 16:02:45.211899993 +0100
+++
/work/SRC/openSUSE:Factory/.python-jupyter-docprovider.new.7067/python-jupyter-docprovider.changes
2025-06-23 14:56:56.400995949 +0200
@@ -1,0 +2,6 @@
+Sat Jun 21 16:59:44 UTC 2025 - Ben Greiner <[email protected]>
+
+- Update to 2.0.2
+ * New subpackage version for jupyter-collaboration 4.0.2
+
+-------------------------------------------------------------------
Old:
----
jupyter_docprovider-1.1.0.tar.gz
New:
----
jupyter_docprovider-2.0.2.tar.gz
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Other differences:
------------------
++++++ python-jupyter-docprovider.spec ++++++
--- /var/tmp/diff_new_pack.1yx7rC/_old 2025-06-23 14:56:57.041022714 +0200
+++ /var/tmp/diff_new_pack.1yx7rC/_new 2025-06-23 14:56:57.041022714 +0200
@@ -16,9 +16,9 @@
#
-%define distversion 1.1
+%define distversion 2.0.2
Name: python-jupyter-docprovider
-Version: 1.1.0
+Version: 2.0.2
Release: 0
Summary: Jupyter extension integrating collaborative shared models
License: BSD-3-Clause
++++++ jupyter_docprovider-1.1.0.tar.gz -> jupyter_docprovider-2.0.2.tar.gz
++++++
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn'
'--exclude=.svnignore' old/jupyter_docprovider-1.1.0/PKG-INFO
new/jupyter_docprovider-2.0.2/PKG-INFO
--- old/jupyter_docprovider-1.1.0/PKG-INFO 2020-02-02 01:00:00.000000000
+0100
+++ new/jupyter_docprovider-2.0.2/PKG-INFO 2020-02-02 01:00:00.000000000
+0100
@@ -1,6 +1,6 @@
-Metadata-Version: 2.3
+Metadata-Version: 2.4
Name: jupyter-docprovider
-Version: 1.1.0
+Version: 2.0.2
Summary: JupyterLab/Jupyter Notebook 7+ extension integrating collaborative
shared models.
Project-URL: Documentation,
https://jupyterlab-realtime-collaboration.readthedocs.io/
Project-URL: Repository, https://github.com/jupyterlab/jupyter-collaboration
@@ -64,6 +64,7 @@
# Copyright (c) Jupyter Development Team.
# Distributed under the terms of the Modified BSD License.
+License-File: LICENSE
Classifier: Framework :: Jupyter
Classifier: Framework :: Jupyter :: JupyterLab
Classifier: Framework :: Jupyter :: JupyterLab :: 4
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn'
'--exclude=.svnignore'
old/jupyter_docprovider-1.1.0/jupyter_docprovider/_version.py
new/jupyter_docprovider-2.0.2/jupyter_docprovider/_version.py
--- old/jupyter_docprovider-1.1.0/jupyter_docprovider/_version.py
2020-02-02 01:00:00.000000000 +0100
+++ new/jupyter_docprovider-2.0.2/jupyter_docprovider/_version.py
2020-02-02 01:00:00.000000000 +0100
@@ -1 +1 @@
-__version__ = "1.1.0"
+__version__ = "2.0.2"
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn'
'--exclude=.svnignore'
old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/package.json
new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/package.json
--- old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/package.json
2020-02-02 01:00:00.000000000 +0100
+++ new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/package.json
2020-02-02 01:00:00.000000000 +0100
@@ -1,6 +1,6 @@
{
"name": "@jupyter/docprovider-extension",
- "version": "3.1.0",
+ "version": "4.0.2",
"description": "JupyterLab - Collaborative Shared Models",
"keywords": [
"jupyter",
@@ -53,29 +53,29 @@
"watch:labextension": "jupyter labextension watch ."
},
"dependencies": {
- "@jupyter/collaborative-drive": "^3.1.0",
- "@jupyter/docprovider": "^3.1.0",
- "@jupyter/ydoc": "^2.0.0 || ^3.0.0",
- "@jupyterlab/application": "^4.2.0",
- "@jupyterlab/apputils": "^4.2.0",
- "@jupyterlab/docregistry": "^4.2.0",
- "@jupyterlab/filebrowser": "^4.2.0",
- "@jupyterlab/fileeditor": "^4.2.0",
- "@jupyterlab/logconsole": "^4.2.0",
- "@jupyterlab/notebook": "^4.2.0",
- "@jupyterlab/settingregistry": "^4.2.0",
- "@jupyterlab/translation": "^4.2.0",
- "@lumino/commands": "^2.1.0",
+ "@jupyter/collaborative-drive": "^4.0.2",
+ "@jupyter/docprovider": "^4.0.2",
+ "@jupyter/ydoc": "^2.1.3 || ^3.0.0",
+ "@jupyterlab/application": "^4.4.0",
+ "@jupyterlab/apputils": "^4.4.0",
+ "@jupyterlab/docregistry": "^4.4.0",
+ "@jupyterlab/filebrowser": "^4.4.0",
+ "@jupyterlab/fileeditor": "^4.4.0",
+ "@jupyterlab/logconsole": "^4.4.0",
+ "@jupyterlab/notebook": "^4.4.0",
+ "@jupyterlab/settingregistry": "^4.4.0",
+ "@jupyterlab/translation": "^4.4.0",
+ "@lumino/commands": "^2.3.2",
"y-protocols": "^1.0.5",
"y-websocket": "^1.3.15",
"yjs": "^13.5.40"
},
"devDependencies": {
- "@jupyterlab/builder": "^4.0.0",
+ "@jupyterlab/builder": "^4.4.0",
"@types/react": "~18.3.1",
"npm-run-all": "^4.1.5",
"rimraf": "^4.1.2",
- "typescript": "~5.0.4"
+ "typescript": "~5.1.6"
},
"publishConfig": {
"access": "public"
@@ -128,7 +128,7 @@
}
},
"_build": {
- "load": "static/remoteEntry.2870ff42f76951af28a0.js",
+ "load": "static/remoteEntry.236b886ba495f686c573.js",
"extension": "./extension",
"style": "./style"
}
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn'
'--exclude=.svnignore'
old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/static/240.b89bafe21cc031ed1f8d.js
new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/static/240.b89bafe21cc031ed1f8d.js
---
old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/static/240.b89bafe21cc031ed1f8d.js
1970-01-01 01:00:00.000000000 +0100
+++
new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/static/240.b89bafe21cc031ed1f8d.js
2020-02-02 01:00:00.000000000 +0100
@@ -0,0 +1 @@
+"use
strict";(self.webpackChunk_jupyter_docprovider_extension=self.webpackChunk_jupyter_docprovider_extension||[]).push([[240],{68:(e,t,n)=>{n.d(t,{A:()=>a});var
o=n(758),r=n.n(o),s=n(935),i=n.n(s)()(r());i.push([e.id,"/*
-----------------------------------------------------------------------------\n|
Copyright (c) Jupyter Development Team.\n| Distributed under the terms of the
Modified BSD
License.\n|----------------------------------------------------------------------------
*/\n\n.jp-timelineSliderWrapper .jp-sliderContainer{\n display: flex;\n
align-items: center;\n}\n\n.jp-Slider {\n height:
4.5px\n}\n\n#jp-slider-status-bar {\n display:
flex;\n}\n\n.jp-timestampDisplay {\n display: flex;\n flex-direction: row;\n
align-items: center;\n gap: 6px;\n}\n\n.jp-restoreBtnContainer {\n width:
192px;\n}\n\n.jp-ToolbarButtonComponent.jp-restoreBtn {\n cursor: pointer;\n
color: var(--jp-layout-color2);\n width: 100%;\n background:
var(--jp-accept-color-normal)\n}\n",""]);con
st a=i},935:e=>{e.exports=function(e){var t=[];return
t.toString=function(){return this.map((function(t){var n="",o=void
0!==t[5];return t[4]&&(n+="@supports (".concat(t[4],") {")),t[2]&&(n+="@media
".concat(t[2]," {")),o&&(n+="@layer".concat(t[5].length>0?" ".concat(t[5]):"","
{")),n+=e(t),o&&(n+="}"),t[2]&&(n+="}"),t[4]&&(n+="}"),n})).join("")},t.i=function(e,n,o,r,s){"string"==typeof
e&&(e=[[null,e,void 0]]);var i={};if(o)for(var a=0;a<this.length;a++){var
c=this[a][0];null!=c&&(i[c]=!0)}for(var l=0;l<e.length;l++){var
d=[].concat(e[l]);o&&i[d[0]]||(void 0!==s&&(void
0===d[5]||(d[1]="@layer".concat(d[5].length>0?" ".concat(d[5]):"","
{").concat(d[1],"}")),d[5]=s),n&&(d[2]?(d[1]="@media ".concat(d[2],"
{").concat(d[1],"}"),d[2]=n):d[2]=n),r&&(d[4]?(d[1]="@supports
(".concat(d[4],")
{").concat(d[1],"}"),d[4]=r):d[4]="".concat(r)),t.push(d))}},t}},758:e=>{e.exports=function(e){return
e[1]}},591:e=>{var t=[];function n(e){for(var
n=-1,o=0;o<t.length;o++)if(t[o].identifier===e){n=o;br
eak}return n}function o(e,o){for(var s={},i=[],a=0;a<e.length;a++){var
c=e[a],l=o.base?c[0]+o.base:c[0],d=s[l]||0,h="".concat(l,"
").concat(d);s[l]=d+1;var
u=n(h),p={css:c[1],media:c[2],sourceMap:c[3],supports:c[4],layer:c[5]};if(-1!==u)t[u].references++,t[u].updater(p);else{var
m=r(p,o);o.byIndex=a,t.splice(a,0,{identifier:h,updater:m,references:1})}i.push(h)}return
i}function r(e,t){var n=t.domAPI(t);return
n.update(e),function(t){if(t){if(t.css===e.css&&t.media===e.media&&t.sourceMap===e.sourceMap&&t.supports===e.supports&&t.layer===e.layer)return;n.update(e=t)}else
n.remove()}}e.exports=function(e,r){var s=o(e=e||[],r=r||{});return
function(e){e=e||[];for(var i=0;i<s.length;i++){var
a=n(s[i]);t[a].references--}for(var c=o(e,r),l=0;l<s.length;l++){var
d=n(s[l]);0===t[d].references&&(t[d].updater(),t.splice(d,1))}s=c}}},128:e=>{var
t={};e.exports=function(e,n){var o=function(e){if(void 0===t[e]){var
n=document.querySelector(e);if(window.HTMLIFrameElement&&n instanceof
window.HTMLI
FrameElement)try{n=n.contentDocument.head}catch(e){n=null}t[e]=n}return
t[e]}(e);if(!o)throw new Error("Couldn't find a style target. This probably
means that the value for the 'insert' parameter is
invalid.");o.appendChild(n)}},51:e=>{e.exports=function(e){var
t=document.createElement("style");return
e.setAttributes(t,e.attributes),e.insert(t,e.options),t}},855:(e,t,n)=>{e.exports=function(e){var
t=n.nc;t&&e.setAttribute("nonce",t)}},359:e=>{e.exports=function(e){if("undefined"==typeof
document)return{update:function(){},remove:function(){}};var
t=e.insertStyleElement(e);return{update:function(n){!function(e,t,n){var
o="";n.supports&&(o+="@supports (".concat(n.supports,")
{")),n.media&&(o+="@media ".concat(n.media," {"));var r=void
0!==n.layer;r&&(o+="@layer".concat(n.layer.length>0?" ".concat(n.layer):"","
{")),o+=n.css,r&&(o+="}"),n.media&&(o+="}"),n.supports&&(o+="}");var
s=n.sourceMap;s&&"undefined"!=typeof btoa&&(o+="\n/*#
sourceMappingURL=data:application/json;base64,".concat
(btoa(unescape(encodeURIComponent(JSON.stringify(s)))),"
*/")),t.styleTagTransform(o,e,t.options)}(t,e,n)},remove:function(){!function(e){if(null===e.parentNode)return!1;e.parentNode.removeChild(e)}(t)}}}},656:e=>{e.exports=function(e,t){if(t.styleSheet)t.styleSheet.cssText=e;else{for(;t.firstChild;)t.removeChild(t.firstChild);t.appendChild(document.createTextNode(e))}}},240:(e,t,n)=>{n.r(t),n.d(t,{ForkManager:()=>K,IForkManagerToken:()=>J,JUPYTER_COLLABORATION_FORK_EVENTS_URI:()=>q,NotebookCellServerExecutor:()=>l,ROOM_FORK_URL:()=>p,RtcContentProvider:()=>k,TimelineWidget:()=>B,WebSocketAwarenessProvider:()=>r,WebSocketProvider:()=>w,requestAPI:()=>m,requestDocSession:()=>f,requestDocumentTimeline:()=>v,requestUndoRedo:()=>g});var
o=n(560);class r extends
o.WebsocketProvider{constructor(e){super(e.url,e.roomID,e.awareness.doc,{awareness:e.awareness}),this._isDisposed=!1,this._awareness=e.awareness,this._user=e.user,this._user.ready.then((()=>this._onUserChanged(this._user))).catch
((e=>console.error(e))),this._user.userChanged.connect(this._onUserChanged,this)}get
isDisposed(){return
this._isDisposed}dispose(){this._isDisposed||(this._user.userChanged.disconnect(this._onUserChanged,this),this._isDisposed=!0,this.destroy())}_onUserChanged(e){this._awareness.setLocalStateField("user",e.identity)}}var
s=n(569),i=n(808),a=n(695),c=n(579);class l{constructor(e){var
t;this._serverSettings=null!==(t=e.serverSettings)&&void
0!==t?t:a.ServerConnection.makeSettings()}async
runCell({cell:e,notebook:t,notebookConfig:n,onCellExecuted:o,onCellExecutionScheduled:r,sessionContext:l,sessionDialogs:d,translator:h}){var
u,p,m;const
f=(h=null!=h?h:c.nullTranslator).load("jupyterlab");switch(e.model.type){case"markdown":e.rendered=!0,e.inputHidden=!1,o({cell:e,success:!0});break;case"code":if(l){if(l.isTerminating){await(0,s.showDialog)({title:f.__("Kernel
Terminating"),body:f.__("The kernel for %1 appears to be terminating. You can
not run any cell for now.",null===(u=l.session)
||void 0===u?void
0:u.path),buttons:[s.Dialog.okButton()]});break}if(l.pendingInput)return
await(0,s.showDialog)({title:f.__("Cell not executed due to pending
input"),body:f.__("The cell has not been executed to avoid kernel deadlock as
there is another pending input! Submit your pending input and try
again."),buttons:[s.Dialog.okButton()]}),!1;if(l.hasNoKernel&&await
l.startKernel()&&d&&await d.selectKernel(l),l.hasNoKernel)return
e.model.sharedModel.transact((()=>{e.model.clearExecution()})),!0;const
n=null===(m=null===(p=null==l?void 0:l.session)||void 0===p?void
0:p.kernel)||void 0===m?void
0:m.id,c=i.URLExt.join(this._serverSettings.baseUrl,`api/kernels/${n}/execute`),h=e.model.sharedModel.getId(),v=t.sharedModel.getState("document_id"),g={method:"POST",body:JSON.stringify({cell_id:h,document_id:v})};r({cell:e});let
y=!1;try{y=(await
a.ServerConnection.makeRequest(c,g,this._serverSettings)).ok}catch(t){if(o({cell:e,success:!1}),e.isDisposed)return!1;throw
t}return o({cell:e,suc
cess:y}),!0}e.model.sharedModel.transact((()=>{e.model.clearExecution()}),!1)}return
Promise.resolve(!0)}}const
d="api/collaboration/session",h="api/collaboration/undo_redo",u="api/collaboration/timeline",p="api/collaboration/fork";async
function m(e="",t={}){const
n=a.ServerConnection.makeSettings(),o=i.URLExt.join(n.baseUrl,e);let
r;try{r=await a.ServerConnection.makeRequest(o,t,n)}catch(e){throw new
a.ServerConnection.NetworkError(e)}let s=await
r.text();if(s.length>0)try{s=JSON.parse(s)}catch(e){console.error("Not a JSON
response body.",r)}if(!r.ok)throw new
a.ServerConnection.ResponseError(r,s.message||s);return s}async function
f(e,t,n){const
o=a.ServerConnection.makeSettings(),r=i.URLExt.join(o.baseUrl,d,encodeURIComponent(n)),s={method:"PUT",body:JSON.stringify({format:e,type:t})};let
c;try{c=await a.ServerConnection.makeRequest(r,s,o)}catch(e){throw new
a.ServerConnection.NetworkError(e)}let l=await
c.text();if(l.length>0)try{l=JSON.parse(l)}catch(e){console.log("Not a JSON
response body.",c)}if(!c.ok)throw new
a.ServerConnection.ResponseError(c,l.message||l);return l}async function
v(e,t,n){const o=a.ServerConnection.makeSettings();let
r=i.URLExt.join(o.baseUrl,u,n);r=r.concat(`?format=${e}&&type=${t}`);const
s={method:"GET"};let c;try{c=await
a.ServerConnection.makeRequest(r,s,o)}catch(e){throw new
a.ServerConnection.NetworkError(e)}return c}async function g(e,t,n,o){const
r=a.ServerConnection.makeSettings();let
s=i.URLExt.join(r.baseUrl,h,encodeURIComponent(e));s=s.concat(`?action=${t}&&steps=${n}&&forkRoom=${o}`);const
c={method:"PUT"};let l;try{l=await
a.ServerConnection.makeRequest(s,c,r)}catch(e){throw new
a.ServerConnection.NetworkError(e)}let d=await
l.text();if(d.length>0)try{d=JSON.parse(d)}catch(e){console.log("Not a JSON
response body.",l)}if(!l.ok)throw new
a.ServerConnection.ResponseError(l,d.message||d);return d}var
y=n(602),_=n(262);class
w{constructor(e){this._onConnectionClosed=e=>{1003===e.code&&(console.error("Document
provider cl
osed:",e.reason),(0,s.showErrorMessage)(this._trans.__("Document session
error"),e.reason,[s.Dialog.okButton()]),this._sharedModel.dispose())},this._onSync=e=>{e&&(this._yWebsocketProvider&&(this._yWebsocketProvider.off("sync",this._onSync),this._sharedModel.ydoc.getMap("state").set("document_id",this._yWebsocketProvider.roomname)),this._ready.resolve())},this._ready=new
_.PromiseDelegate,this._isDisposed=!1,this._path=e.path,this._contentType=e.contentType,this._format=e.format,this._serverUrl=e.url,this._sharedModel=e.model,this._awareness=e.model.awareness,this._yWebsocketProvider=null,this._trans=e.translator;const
t=e.user;t.ready.then((()=>{this._onUserChanged(t)})).catch((e=>console.error(e))),t.userChanged.connect(this._onUserChanged,this),this._connect().catch((e=>console.warn(e)))}get
isDisposed(){return this._isDisposed}get ready(){return
this._ready.promise}get contentType(){return this._contentType}get
format(){return this._format}dispose(){var e,t,n;this.isDisposed||(t
his._isDisposed=!0,null===(e=this._yWebsocketProvider)||void
0===e||e.off("connection-close",this._onConnectionClosed),null===(t=this._yWebsocketProvider)||void
0===t||t.off("sync",this._onSync),null===(n=this._yWebsocketProvider)||void
0===n||n.destroy(),this._disconnect(),y.Signal.clearData(this))}async
reconnect(){this._disconnect(),this._connect()}async _connect(){const e=await
f(this._format,this._contentType,this._path);this._yWebsocketProvider=new
o.WebsocketProvider(this._serverUrl,`${e.format}:${e.type}:${e.fileId}`,this._sharedModel.ydoc,{disableBc:!0,params:{sessionId:e.sessionId},awareness:this._awareness}),this._yWebsocketProvider.on("sync",this._onSync),this._yWebsocketProvider.on("connection-close",this._onConnectionClosed)}async
connectToForkDoc(e,t){this._disconnect(),this._yWebsocketProvider=new
o.WebsocketProvider(this._serverUrl,e,this._sharedModel.ydoc,{disableBc:!0,params:{sessionId:t},awareness:this._awareness})}get
wsProvider(){return this._yWebsocketProvider
}_disconnect(){var e,t,n;null===(e=this._yWebsocketProvider)||void
0===e||e.off("connection-close",this._onConnectionClosed),null===(t=this._yWebsocketProvider)||void
0===t||t.off("sync",this._onSync),null===(n=this._yWebsocketProvider)||void
0===n||n.destroy(),this._yWebsocketProvider=null}_onUserChanged(e){this._awareness.setLocalStateField("user",e.identity)}}const
S="true"===i.PageConfig.getOption("disableRTC");class k extends
a.RestContentProvider{constructor(e){super(e),this._onCreate=(e,t)=>{var
n,o;if("string"==typeof e.format)try{const r=new
w({url:i.URLExt.join(this._serverSettings.wsUrl,"api/collaboration/room"),path:e.path,format:e.format,contentType:e.contentType,model:t,user:this._user,translator:this._trans}),s=((null===(n=this._globalAwareness)||void
0===n?void
0:n.getLocalState())||{}).documents||[];s.includes(e.path)||(s.push(e.path),null===(o=this._globalAwareness)||void
0===o||o.setLocalStateField("documents",s));const
a=`${e.format}:${e.contentType}:${e.path}`;t
his._providers.set(a,r),t.changed.connect((async(n,o)=>{var
r;if(!o.stateChange)return;const
s=o.stateChange.filter((e=>"hash"===e.name));if(0===s.length)return;s.length>1&&console.error("Unexpected
multiple changes to hash value in a single transaction");const
i=s[0],a=null!==(r=t.state.path)&&void 0!==r?r:e.path,c=await
this.get(a,{content:!1});this._ydriveFileChanged.emit({type:"save",newValue:{...c,hash:i.newValue},oldValue:{hash:i.oldValue}})})),t.disposed.connect((()=>{var
t,n;const
o=this._providers.get(a);o&&(o.dispose(),this._providers.delete(a));const
r=((null===(t=this._globalAwareness)||void 0===t?void
0:t.getLocalState())||{}).documents||[],s=r.indexOf(e.path);s>-1&&r.splice(s,1),null===(n=this._globalAwareness)||void
0===n||n.setLocalStateField("documents",r)}))}catch(t){console.error(`Failed
to open websocket connection for
${e.path}.\n:${t}`)}},this._ydriveFileChanged=new
y.Signal(this),this._user=e.user,this._trans=e.trans,this._globalAwareness=e.globalAwareness,thi
s._serverSettings=e.serverSettings,this.sharedModelFactory=new
b(this._onCreate),this._providers=new Map}get providers(){return
this._providers}async get(e,t){if(t&&t.format&&t.type){const
n=`${t.format}:${t.type}:${e}`,o=this._providers.get(n);if(o){const[n]=await
Promise.all([super.get(e,{...t,content:!1}),o.ready]);return{...n,format:t.format}}}return
super.get(e,t)}async save(e,t={}){if(t.format&&t.type){const
n=`${t.format}:${t.type}:${e}`;if(this._providers.get(n)){const
n={type:t.type,format:t.format,content:!1};return this.get(e,n)}}return
super.save(e,t)}get fileChanged(){return this._ydriveFileChanged}}class
b{constructor(e){this._onCreate=e,this.collaborative=!S,this.documentFactories=new
Map}registerDocumentFactory(e,t){if(this.documentFactories.has(e))throw new
Error(`The content type ${e} already
exists`);this.documentFactories.set(e,t)}createNew(e){if("string"==typeof
e.format){if(this.collaborative&&e.collaborative&&this.documentFactories.has(e.contentType)){const
t=
this.documentFactories.get(e.contentType)(e);return
this._onCreate(e,t),t}}else console.warn(`Only defined format are supported;
got ${e.format}.`)}}var
C=n(345),T=n.n(C),E=n(591),x=n.n(E),R=n(359),U=n.n(R),D=n(128),P=n.n(D),$=n(855),N=n.n($),j=n(51),I=n.n(j),L=n(656),M=n.n(L),F=n(68),A={};A.styleTagTransform=M(),A.setAttributes=N(),A.insert=P().bind(null,"head"),A.domAPI=U(),A.insertStyleElement=I(),x()(F.A,A),F.A&&F.A.locals&&F.A.locals;var
W=n(989);const
O=({apiURL:e,provider:t,contentType:n,format:o,documentTimelineUrl:r})=>{const[i,a]=(0,C.useState)({roomId:"",timestamps:[],forkRoom:"",sessionId:""}),[c,l]=(0,C.useState)(i.timestamps.length-1),[d,h]=(0,C.useState)(!1),[u,p]=(0,C.useState)(!1),m=(0,C.useRef)(!0),y=(0,C.useRef)(!0),_=(0,C.useRef)(null);function
w(e){try{const t=new URL(e).pathname,n=t.lastIndexOf(r);if(-1===n)throw new
Error(`API segment "${r}" not found in URL.`);return
t.slice(n+r.length)}catch(e){return console.error("Invalid URL or unable to
extract filename:
",e),""}}return
T().createElement("div",{className:"jp-sliderContainer"},T().createElement("div",{onClick:()=>{!async
function(r){try{if(m.current){const i=await v(o,n,r);if(!i.ok)throw
404===i.status?new Error("Not found"):503===i.status?new Error("WebSocket
closed"):new Error(`Failed to fetch data: ${i.statusText}`);const c=await
i.text();let d={roomId:"",timestamps:[],forkRoom:"",sessionId:""};return
c&&(s.Notification.warning("Document is now in read-only mode. Changes will not
be
saved.",{autoClose:2500}),d=JSON.parse(c),a(d),l(d.timestamps.length-1),t.connectToForkDoc(d.forkRoom,d.sessionId),_.current=await
f(o,n,w(e))),h(!0),m.current=!1,d}}catch(e){console.error("Error fetching
data:",e)}}(w(e))},className:"jp-mod-highlighted",title:"Document
Timeline"},T().createElement(W.historyIcon.react,{marginRight:"4px"})),d&&T().createElement("div",{className:"jp-timestampDisplay"},T().createElement("input",{type:"range",min:0,max:i.timestamps.length-1,value:c,onChange:async
e=>{const
t=parseInt(e.target.value),n=Math.abs(t-c);try{const e=function(e){return
e<c?"undo":"redo"}(t);if(l(t),y.current&&(p(!0),y.current=!1),!_.current)return
void console.error("Session is not initialized");await
g(`${_.current.format}:${_.current.type}:${_.current.fileId}`,e,n,i.forkRoom)}catch(e){console.error("Error
fetching or applying
updates:",e)}},className:"jp-Slider"}),T().createElement("div",null,T().createElement("strong",null,w(e).split("/").pop(),"
"),"
"),u&&T().createElement("div",{className:"jp-restoreBtnContainer"},T().createElement("button",{onClick:async()=>{if(!_.current)return
void console.error("Session is not initialized");const e=await
g(`${_.current.format}:${_.current.type}:${_.current.fileId}`,"restore",0,i.forkRoom);200===e.code?(s.Notification.success(e.status,{autoClose:4e3}),t.reconnect(),h(!1),m.current=!0):s.Notification.error(e.status,{autoClose:4e3})},className:"jp-ToolbarButtonComponent
jp-restoreBtn"},"Restore version"," ",(e=>{const t=new Date(1e3*
e);return`${t.getFullYear()}-${String(t.getMonth()+1).padStart(2,"0")}-${String(t.getDate()).padStart(2,"0")}
${String(t.getHours()).padStart(2,"0")}:${String(t.getMinutes()).padStart(2,"0")}:${String(t.getSeconds()).padStart(2,"0")}`})(i.timestamps[c])))))};class
B extends
s.ReactWidget{constructor(e,t,n,o,r){super(),this.apiURL=e,this.provider=t,this.contentType=n,this.format=o,this.documentTimelineUrl=r,this.addClass("jp-timelineSliderWrapper")}render(){return
C.createElement(O,{key:this.apiURL,apiURL:this.apiURL,provider:this.provider,contentType:this.contentType,format:this.format,documentTimelineUrl:this.documentTimelineUrl})}updateContent(e,t){this.apiURL=e,this.provider=t,this.contentType=this.provider.contentType,this.format=this.provider.format,this.update()}}const
J=new
_.Token("@jupyter/docprovider:IForkManagerToken"),q="https://schema.jupyter.org/jupyter_collaboration/fork/v1";class
K{constructor(e){this._disposed=!1,this._forkAddedSignal=new
y.Signal(this),this._forkDe
letedSignal=new
y.Signal(this);const{contentProvider:t,eventManager:n}=e;this._contentProvider=t,this._eventManager=n,this._eventManager.stream.connect(this._handleEvent,this)}get
isDisposed(){return this._disposed}get forkAdded(){return
this._forkAddedSignal}get forkDeleted(){return
this._forkDeletedSignal}dispose(){var
e;this._disposed||(null===(e=this._eventManager)||void
0===e||e.stream.disconnect(this._handleEvent),this._disposed=!0)}async
createFork(e){const{rootId:t,title:n,description:o,synchronize:r}=e,s={method:"PUT",body:JSON.stringify({title:n,description:o,synchronize:r})},a=i.URLExt.join(p,t);return
await m(a,s)}async getAllForks(e){const t=i.URLExt.join(p,e);return await
m(t,{method:"GET"})}async
deleteFork(e){const{forkId:t,merge:n}=e,o=i.URLExt.join(p,t),r=i.URLExt.objectToQueryString({merge:n});await
m(`${o}${r}`,{method:"DELETE"})}getProvider(e){const{documentPath:t,format:n,type:o}=e,r=this._contentProvider;if(r){const
e=t;return r.providers.get(`${n}:${o}:${e}`)
}}_handleEvent(e,t){if(t.schema_id===q)switch(t.action){case"create":this._forkAddedSignal.emit(t);break;case"delete":this._forkDeletedSignal.emit(t)}}}}}]);
\ No newline at end of file
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn'
'--exclude=.svnignore'
old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/static/240.dd1dbd559d6c95c85b3f.js
new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/static/240.dd1dbd559d6c95c85b3f.js
---
old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/static/240.dd1dbd559d6c95c85b3f.js
2020-02-02 01:00:00.000000000 +0100
+++
new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/static/240.dd1dbd559d6c95c85b3f.js
1970-01-01 01:00:00.000000000 +0100
@@ -1 +0,0 @@
-"use
strict";(self.webpackChunk_jupyter_docprovider_extension=self.webpackChunk_jupyter_docprovider_extension||[]).push([[240],{68:(e,t,n)=>{n.d(t,{A:()=>a});var
o=n(758),r=n.n(o),s=n(935),i=n.n(s)()(r());i.push([e.id,"/*
-----------------------------------------------------------------------------\n|
Copyright (c) Jupyter Development Team.\n| Distributed under the terms of the
Modified BSD
License.\n|----------------------------------------------------------------------------
*/\n\n.jp-timelineSliderWrapper .jp-sliderContainer{\n display: flex;\n
align-items: center;\n}\n\n.jp-Slider {\n height:
4.5px\n}\n\n#jp-slider-status-bar {\n display:
flex;\n}\n\n.jp-timestampDisplay {\n display: flex;\n flex-direction: row;\n
align-items: center;\n gap: 6px;\n}\n\n.jp-restoreBtnContainer {\n width:
192px;\n}\n\n.jp-ToolbarButtonComponent.jp-restoreBtn {\n cursor: pointer;\n
color: var(--jp-layout-color2);\n width: 100%;\n background:
var(--jp-accept-color-normal)\n}\n",""]);con
st a=i},935:e=>{e.exports=function(e){var t=[];return
t.toString=function(){return this.map((function(t){var n="",o=void
0!==t[5];return t[4]&&(n+="@supports (".concat(t[4],") {")),t[2]&&(n+="@media
".concat(t[2]," {")),o&&(n+="@layer".concat(t[5].length>0?" ".concat(t[5]):"","
{")),n+=e(t),o&&(n+="}"),t[2]&&(n+="}"),t[4]&&(n+="}"),n})).join("")},t.i=function(e,n,o,r,s){"string"==typeof
e&&(e=[[null,e,void 0]]);var i={};if(o)for(var a=0;a<this.length;a++){var
c=this[a][0];null!=c&&(i[c]=!0)}for(var l=0;l<e.length;l++){var
d=[].concat(e[l]);o&&i[d[0]]||(void 0!==s&&(void
0===d[5]||(d[1]="@layer".concat(d[5].length>0?" ".concat(d[5]):"","
{").concat(d[1],"}")),d[5]=s),n&&(d[2]?(d[1]="@media ".concat(d[2],"
{").concat(d[1],"}"),d[2]=n):d[2]=n),r&&(d[4]?(d[1]="@supports
(".concat(d[4],")
{").concat(d[1],"}"),d[4]=r):d[4]="".concat(r)),t.push(d))}},t}},758:e=>{e.exports=function(e){return
e[1]}},591:e=>{var t=[];function n(e){for(var
n=-1,o=0;o<t.length;o++)if(t[o].identifier===e){n=o;br
eak}return n}function o(e,o){for(var s={},i=[],a=0;a<e.length;a++){var
c=e[a],l=o.base?c[0]+o.base:c[0],d=s[l]||0,h="".concat(l,"
").concat(d);s[l]=d+1;var
u=n(h),p={css:c[1],media:c[2],sourceMap:c[3],supports:c[4],layer:c[5]};if(-1!==u)t[u].references++,t[u].updater(p);else{var
m=r(p,o);o.byIndex=a,t.splice(a,0,{identifier:h,updater:m,references:1})}i.push(h)}return
i}function r(e,t){var n=t.domAPI(t);return
n.update(e),function(t){if(t){if(t.css===e.css&&t.media===e.media&&t.sourceMap===e.sourceMap&&t.supports===e.supports&&t.layer===e.layer)return;n.update(e=t)}else
n.remove()}}e.exports=function(e,r){var s=o(e=e||[],r=r||{});return
function(e){e=e||[];for(var i=0;i<s.length;i++){var
a=n(s[i]);t[a].references--}for(var c=o(e,r),l=0;l<s.length;l++){var
d=n(s[l]);0===t[d].references&&(t[d].updater(),t.splice(d,1))}s=c}}},128:e=>{var
t={};e.exports=function(e,n){var o=function(e){if(void 0===t[e]){var
n=document.querySelector(e);if(window.HTMLIFrameElement&&n instanceof
window.HTMLI
FrameElement)try{n=n.contentDocument.head}catch(e){n=null}t[e]=n}return
t[e]}(e);if(!o)throw new Error("Couldn't find a style target. This probably
means that the value for the 'insert' parameter is
invalid.");o.appendChild(n)}},51:e=>{e.exports=function(e){var
t=document.createElement("style");return
e.setAttributes(t,e.attributes),e.insert(t,e.options),t}},855:(e,t,n)=>{e.exports=function(e){var
t=n.nc;t&&e.setAttribute("nonce",t)}},740:e=>{e.exports=function(e){if("undefined"==typeof
document)return{update:function(){},remove:function(){}};var
t=e.insertStyleElement(e);return{update:function(n){!function(e,t,n){var
o="";n.supports&&(o+="@supports (".concat(n.supports,")
{")),n.media&&(o+="@media ".concat(n.media," {"));var r=void
0!==n.layer;r&&(o+="@layer".concat(n.layer.length>0?" ".concat(n.layer):"","
{")),o+=n.css,r&&(o+="}"),n.media&&(o+="}"),n.supports&&(o+="}");var
s=n.sourceMap;s&&"undefined"!=typeof btoa&&(o+="\n/*#
sourceMappingURL=data:application/json;base64,".concat
(btoa(unescape(encodeURIComponent(JSON.stringify(s)))),"
*/")),t.styleTagTransform(o,e,t.options)}(t,e,n)},remove:function(){!function(e){if(null===e.parentNode)return!1;e.parentNode.removeChild(e)}(t)}}}},656:e=>{e.exports=function(e,t){if(t.styleSheet)t.styleSheet.cssText=e;else{for(;t.firstChild;)t.removeChild(t.firstChild);t.appendChild(document.createTextNode(e))}}},240:(e,t,n)=>{n.r(t),n.d(t,{ForkManager:()=>K,IForkManagerToken:()=>J,JUPYTER_COLLABORATION_FORK_EVENTS_URI:()=>q,NotebookCellServerExecutor:()=>l,ROOM_FORK_URL:()=>p,TimelineWidget:()=>B,WebSocketAwarenessProvider:()=>r,WebSocketProvider:()=>w,YDrive:()=>k,requestAPI:()=>m,requestDocSession:()=>f,requestDocumentTimeline:()=>v,requestUndoRedo:()=>g});var
o=n(560);class r extends
o.WebsocketProvider{constructor(e){super(e.url,e.roomID,e.awareness.doc,{awareness:e.awareness}),this._isDisposed=!1,this._awareness=e.awareness,this._user=e.user,this._user.ready.then((()=>this._onUserChanged(this._user))).catch((e=>console
.error(e))),this._user.userChanged.connect(this._onUserChanged,this)}get
isDisposed(){return
this._isDisposed}dispose(){this._isDisposed||(this._user.userChanged.disconnect(this._onUserChanged,this),this._isDisposed=!0,this.destroy())}_onUserChanged(e){this._awareness.setLocalStateField("user",e.identity)}}var
s=n(123),i=n(672),a=n(943),c=n(624);class l{constructor(e){var
t;this._serverSettings=null!==(t=e.serverSettings)&&void
0!==t?t:a.ServerConnection.makeSettings()}async
runCell({cell:e,notebook:t,notebookConfig:n,onCellExecuted:o,onCellExecutionScheduled:r,sessionContext:l,sessionDialogs:d,translator:h}){var
u,p,m;const
f=(h=null!=h?h:c.nullTranslator).load("jupyterlab");switch(e.model.type){case"markdown":e.rendered=!0,e.inputHidden=!1,o({cell:e,success:!0});break;case"code":if(l){if(l.isTerminating){await(0,s.showDialog)({title:f.__("Kernel
Terminating"),body:f.__("The kernel for %1 appears to be terminating. You can
not run any cell for now.",null===(u=l.session)||void 0===u
?void 0:u.path),buttons:[s.Dialog.okButton()]});break}if(l.pendingInput)return
await(0,s.showDialog)({title:f.__("Cell not executed due to pending
input"),body:f.__("The cell has not been executed to avoid kernel deadlock as
there is another pending input! Submit your pending input and try
again."),buttons:[s.Dialog.okButton()]}),!1;if(l.hasNoKernel&&await
l.startKernel()&&d&&await d.selectKernel(l),l.hasNoKernel)return
e.model.sharedModel.transact((()=>{e.model.clearExecution()})),!0;const
n=null===(m=null===(p=null==l?void 0:l.session)||void 0===p?void
0:p.kernel)||void 0===m?void
0:m.id,c=i.URLExt.join(this._serverSettings.baseUrl,`api/kernels/${n}/execute`),h=e.model.sharedModel.getId(),v=t.sharedModel.getState("document_id"),g={method:"POST",body:JSON.stringify({cell_id:h,document_id:v})};r({cell:e});let
y=!1;try{y=(await
a.ServerConnection.makeRequest(c,g,this._serverSettings)).ok}catch(t){if(o({cell:e,success:!1}),e.isDisposed)return!1;throw
t}return o({cell:e,success:y}),!0}
e.model.sharedModel.transact((()=>{e.model.clearExecution()}),!1)}return
Promise.resolve(!0)}}const
d="api/collaboration/session",h="api/collaboration/undo_redo",u="api/collaboration/timeline",p="api/collaboration/fork";async
function m(e="",t={}){const
n=a.ServerConnection.makeSettings(),o=i.URLExt.join(n.baseUrl,e);let
r;try{r=await a.ServerConnection.makeRequest(o,t,n)}catch(e){throw new
a.ServerConnection.NetworkError(e)}let s=await
r.text();if(s.length>0)try{s=JSON.parse(s)}catch(e){console.error("Not a JSON
response body.",r)}if(!r.ok)throw new
a.ServerConnection.ResponseError(r,s.message||s);return s}async function
f(e,t,n){const
o=a.ServerConnection.makeSettings(),r=i.URLExt.join(o.baseUrl,d,encodeURIComponent(n)),s={method:"PUT",body:JSON.stringify({format:e,type:t})};let
c;try{c=await a.ServerConnection.makeRequest(r,s,o)}catch(e){throw new
a.ServerConnection.NetworkError(e)}let l=await
c.text();if(l.length>0)try{l=JSON.parse(l)}catch(e){console.log("Not a JSON
response bo
dy.",c)}if(!c.ok)throw new
a.ServerConnection.ResponseError(c,l.message||l);return l}async function
v(e,t,n){const o=a.ServerConnection.makeSettings();let
r=i.URLExt.join(o.baseUrl,u,n);r=r.concat(`?format=${e}&&type=${t}`);const
s={method:"GET"};let c;try{c=await
a.ServerConnection.makeRequest(r,s,o)}catch(e){throw new
a.ServerConnection.NetworkError(e)}return c}async function g(e,t,n,o){const
r=a.ServerConnection.makeSettings();let
s=i.URLExt.join(r.baseUrl,h,encodeURIComponent(e));s=s.concat(`?action=${t}&&steps=${n}&&forkRoom=${o}`);const
c={method:"PUT"};let l;try{l=await
a.ServerConnection.makeRequest(s,c,r)}catch(e){throw new
a.ServerConnection.NetworkError(e)}let d=await
l.text();if(d.length>0)try{d=JSON.parse(d)}catch(e){console.log("Not a JSON
response body.",l)}if(!l.ok)throw new
a.ServerConnection.ResponseError(l,d.message||d);return d}var
y=n(602),_=n(262);class
w{constructor(e){this._onConnectionClosed=e=>{1003===e.code&&(console.error("Document
provider closed:",e.rea
son),(0,s.showErrorMessage)(this._trans.__("Document session
error"),e.reason,[s.Dialog.okButton()]),this._sharedModel.dispose())},this._onSync=e=>{e&&(this._yWebsocketProvider&&(this._yWebsocketProvider.off("sync",this._onSync),this._sharedModel.ydoc.getMap("state").set("document_id",this._yWebsocketProvider.roomname)),this._ready.resolve())},this._ready=new
_.PromiseDelegate,this._isDisposed=!1,this._path=e.path,this._contentType=e.contentType,this._format=e.format,this._serverUrl=e.url,this._sharedModel=e.model,this._awareness=e.model.awareness,this._yWebsocketProvider=null,this._trans=e.translator;const
t=e.user;t.ready.then((()=>{this._onUserChanged(t)})).catch((e=>console.error(e))),t.userChanged.connect(this._onUserChanged,this),this._connect().catch((e=>console.warn(e)))}get
isDisposed(){return this._isDisposed}get ready(){return
this._ready.promise}get contentType(){return this._contentType}get
format(){return this._format}dispose(){var e,t,n;this.isDisposed||(this._isDispo
sed=!0,null===(e=this._yWebsocketProvider)||void
0===e||e.off("connection-close",this._onConnectionClosed),null===(t=this._yWebsocketProvider)||void
0===t||t.off("sync",this._onSync),null===(n=this._yWebsocketProvider)||void
0===n||n.destroy(),this._disconnect(),y.Signal.clearData(this))}async
reconnect(){this._disconnect(),this._connect()}async _connect(){const e=await
f(this._format,this._contentType,this._path);this._yWebsocketProvider=new
o.WebsocketProvider(this._serverUrl,`${e.format}:${e.type}:${e.fileId}`,this._sharedModel.ydoc,{disableBc:!0,params:{sessionId:e.sessionId},awareness:this._awareness}),this._yWebsocketProvider.on("sync",this._onSync),this._yWebsocketProvider.on("connection-close",this._onConnectionClosed)}async
connectToForkDoc(e,t){this._disconnect(),this._yWebsocketProvider=new
o.WebsocketProvider(this._serverUrl,e,this._sharedModel.ydoc,{disableBc:!0,params:{sessionId:t},awareness:this._awareness})}get
wsProvider(){return this._yWebsocketProvider}_disconnect
(){var e,t,n;null===(e=this._yWebsocketProvider)||void
0===e||e.off("connection-close",this._onConnectionClosed),null===(t=this._yWebsocketProvider)||void
0===t||t.off("sync",this._onSync),null===(n=this._yWebsocketProvider)||void
0===n||n.destroy(),this._yWebsocketProvider=null}_onUserChanged(e){this._awareness.setLocalStateField("user",e.identity)}}const
S="true"===i.PageConfig.getOption("disableRTC");class k extends
a.Drive{constructor(e,t,n){super({name:"RTC"}),this._onCreate=(e,t)=>{var
n,o;if("string"==typeof e.format)try{const r=new
w({url:i.URLExt.join(this.serverSettings.wsUrl,"api/collaboration/room"),path:e.path,format:e.format,contentType:e.contentType,model:t,user:this._user,translator:this._trans}),s=((null===(n=this._globalAwareness)||void
0===n?void
0:n.getLocalState())||{}).documents||[];s.includes(e.path)||(s.push(`${this.name}:${e.path}`),null===(o=this._globalAwareness)||void
0===o||o.setLocalStateField("documents",s));const
a=`${e.format}:${e.contentType}:${e.pa
th}`;this._providers.set(a,r),t.changed.connect((async(n,o)=>{var
r;if(!o.stateChange)return;const
s=o.stateChange.filter((e=>"hash"===e.name));if(0===s.length)return;s.length>1&&console.error("Unexpected
multiple changes to hash value in a single transaction");const
i=s[0],a=null!==(r=t.state.path)&&void 0!==r?r:e.path,c=await
this.get(a,{content:!1});this._ydriveFileChanged.emit({type:"save",newValue:{...c,hash:i.newValue},oldValue:{hash:i.oldValue}})})),t.disposed.connect((()=>{var
t,n;const
o=this._providers.get(a);o&&(o.dispose(),this._providers.delete(a));const
r=((null===(t=this._globalAwareness)||void 0===t?void
0:t.getLocalState())||{}).documents||[],s=r.indexOf(`${this.name}:${e.path}`);s>-1&&r.splice(s,1),null===(n=this._globalAwareness)||void
0===n||n.setLocalStateField("documents",r)}))}catch(t){console.error(`Failed
to open websocket connection for
${e.path}.\n:${t}`)}},this._ydriveFileChanged=new
y.Signal(this),this._user=e,this._trans=t,this._globalAwareness=n,this._
providers=new Map,this.sharedModelFactory=new
b(this._onCreate),super.fileChanged.connect(((e,t)=>{this._ydriveFileChanged.emit(t)}))}get
providers(){return
this._providers}dispose(){this.isDisposed||(this._providers.forEach((e=>e.dispose())),this._providers.clear(),super.dispose())}async
get(e,t){if(t&&t.format&&t.type){const
n=`${t.format}:${t.type}:${e}`,o=this._providers.get(n);if(o){const[n]=await
Promise.all([super.get(e,{...t,content:!1}),o.ready]);return{...n,format:t.format}}}return
super.get(e,t)}async save(e,t={}){if(t.format&&t.type){const
n=`${t.format}:${t.type}:${e}`;if(this._providers.get(n)){const
n={type:t.type,format:t.format,content:!1};return this.get(e,n)}}return
super.save(e,t)}get fileChanged(){return this._ydriveFileChanged}}class
b{constructor(e){this._onCreate=e,this.collaborative=!S,this.documentFactories=new
Map}registerDocumentFactory(e,t){if(this.documentFactories.has(e))throw new
Error(`The content type ${e} already exists`);this.documentFactories.set
(e,t)}createNew(e){if("string"==typeof
e.format){if(this.collaborative&&e.collaborative&&this.documentFactories.has(e.contentType)){const
t=this.documentFactories.get(e.contentType)(e);return
this._onCreate(e,t),t}}else console.warn(`Only defined format are supported;
got ${e.format}.`)}}var
C=n(345),T=n.n(C),E=n(591),x=n.n(E),R=n(740),U=n.n(R),D=n(128),$=n.n(D),N=n(855),P=n.n(N),j=n(51),I=n.n(j),L=n(656),M=n.n(L),F=n(68),W={};W.styleTagTransform=M(),W.setAttributes=P(),W.insert=$().bind(null,"head"),W.domAPI=U(),W.insertStyleElement=I(),x()(F.A,W),F.A&&F.A.locals&&F.A.locals;var
A=n(597);const
O=({apiURL:e,provider:t,contentType:n,format:o,documentTimelineUrl:r})=>{const[i,a]=(0,C.useState)({roomId:"",timestamps:[],forkRoom:"",sessionId:""}),[c,l]=(0,C.useState)(i.timestamps.length-1),[d,h]=(0,C.useState)(!1),[u,p]=(0,C.useState)(!1),m=(0,C.useRef)(!0),y=(0,C.useRef)(!0),_=(0,C.useRef)(null);function
w(e){try{const t=new URL(e).pathname,n=t.lastIndexOf(r);if(-1===n)throw new
Error(
`API segment "${r}" not found in URL.`);return
t.slice(n+r.length)}catch(e){return console.error("Invalid URL or unable to
extract filename:",e),""}}return
T().createElement("div",{className:"jp-sliderContainer"},T().createElement("div",{onClick:()=>{!async
function(r){try{if(m.current){const i=await v(o,n,r);if(!i.ok)throw
404===i.status?new Error("Not found"):503===i.status?new Error("WebSocket
closed"):new Error(`Failed to fetch data: ${i.statusText}`);const c=await
i.text();let d={roomId:"",timestamps:[],forkRoom:"",sessionId:""};return
c&&(s.Notification.warning("Document is now in read-only mode. Changes will not
be
saved.",{autoClose:2500}),d=JSON.parse(c),a(d),l(d.timestamps.length-1),t.connectToForkDoc(d.forkRoom,d.sessionId),_.current=await
f(o,n,w(e))),h(!0),m.current=!1,d}}catch(e){console.error("Error fetching
data:",e)}}(w(e))},className:"jp-mod-highlighted",title:"Document
Timeline"},T().createElement(A.historyIcon.react,{marginRight:"4px"})),d&&T().createElement("div
",{className:"jp-timestampDisplay"},T().createElement("input",{type:"range",min:0,max:i.timestamps.length-1,value:c,onChange:async
e=>{const t=parseInt(e.target.value),n=Math.abs(t-c);try{const
e=function(e){return
e<c?"undo":"redo"}(t);if(l(t),y.current&&(p(!0),y.current=!1),!_.current)return
void console.error("Session is not initialized");await
g(`${_.current.format}:${_.current.type}:${_.current.fileId}`,e,n,i.forkRoom)}catch(e){console.error("Error
fetching or applying
updates:",e)}},className:"jp-Slider"}),T().createElement("div",null,T().createElement("strong",null,w(e).split("/").pop(),"
"),"
"),u&&T().createElement("div",{className:"jp-restoreBtnContainer"},T().createElement("button",{onClick:async()=>{if(!_.current)return
void console.error("Session is not initialized");const e=await
g(`${_.current.format}:${_.current.type}:${_.current.fileId}`,"restore",0,i.forkRoom);200===e.code?(s.Notification.success(e.status,{autoClose:4e3}),t.reconnect(),h(!1),m.current=!0):s.Notific
ation.error(e.status,{autoClose:4e3})},className:"jp-ToolbarButtonComponent
jp-restoreBtn"},"Restore version"," ",(e=>{const t=new
Date(1e3*e);return`${t.getFullYear()}-${String(t.getMonth()+1).padStart(2,"0")}-${String(t.getDate()).padStart(2,"0")}
${String(t.getHours()).padStart(2,"0")}:${String(t.getMinutes()).padStart(2,"0")}:${String(t.getSeconds()).padStart(2,"0")}`})(i.timestamps[c])))))};class
B extends
s.ReactWidget{constructor(e,t,n,o,r){super(),this.apiURL=e,this.provider=t,this.contentType=n,this.format=o,this.documentTimelineUrl=r,this.addClass("jp-timelineSliderWrapper")}render(){return
C.createElement(O,{key:this.apiURL,apiURL:this.apiURL,provider:this.provider,contentType:this.contentType,format:this.format,documentTimelineUrl:this.documentTimelineUrl})}updateContent(e,t){this.apiURL=e,this.provider=t,this.contentType=this.provider.contentType,this.format=this.provider.format,this.update()}}const
J=new _.Token("@jupyter/docprovider:IForkManagerToken"),q="https://sche
ma.jupyter.org/jupyter_collaboration/fork/v1";class
K{constructor(e){this._disposed=!1,this._forkAddedSignal=new
y.Signal(this),this._forkDeletedSignal=new
y.Signal(this);const{drive:t,eventManager:n}=e;this._drive=t,this._eventManager=n,this._eventManager.stream.connect(this._handleEvent,this)}get
isDisposed(){return this._disposed}get forkAdded(){return
this._forkAddedSignal}get forkDeleted(){return
this._forkDeletedSignal}dispose(){var
e;this._disposed||(null===(e=this._eventManager)||void
0===e||e.stream.disconnect(this._handleEvent),this._disposed=!0)}async
createFork(e){const{rootId:t,title:n,description:o,synchronize:r}=e,s={method:"PUT",body:JSON.stringify({title:n,description:o,synchronize:r})},a=i.URLExt.join(p,t);return
await m(a,s)}async getAllForks(e){const t=i.URLExt.join(p,e);return await
m(t,{method:"GET"})}async
deleteFork(e){const{forkId:t,merge:n}=e,o=i.URLExt.join(p,t),r=i.URLExt.objectToQueryString({merge:n});await
m(`${o}${r}`,{method:"DELETE"})}getProvider(e){
const{documentPath:t,format:n,type:o}=e,r=this._drive;if(r){const e=r.name;let
s=t;return
t.startsWith(e)&&(s=t.slice(e.length+1)),r.providers.get(`${n}:${o}:${s}`)}}_handleEvent(e,t){if(t.schema_id===q)switch(t.action){case"create":this._forkAddedSignal.emit(t);break;case"delete":this._forkDeletedSignal.emit(t)}}}}}]);
\ No newline at end of file
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn'
'--exclude=.svnignore'
old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/static/444.12adfae9a2b50e91531f.js
new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/static/444.12adfae9a2b50e91531f.js
---
old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/static/444.12adfae9a2b50e91531f.js
2020-02-02 01:00:00.000000000 +0100
+++
new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/static/444.12adfae9a2b50e91531f.js
1970-01-01 01:00:00.000000000 +0100
@@ -1 +0,0 @@
-"use
strict";(self.webpackChunk_jupyter_docprovider_extension=self.webpackChunk_jupyter_docprovider_extension||[]).push([[444],{444:(e,o,r)=>{r.r(o),r.d(o,{ICollaborativeDrive:()=>a,IGlobalAwareness:()=>l});var
n=r(262);const a=new
n.Token("@jupyter/collaboration-extension:ICollaborativeDrive"),l=new
n.Token("@jupyter/collaboration:IGlobalAwareness")}}]);
\ No newline at end of file
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn'
'--exclude=.svnignore'
old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/static/444.13de0fd44849e3f7d780.js
new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/static/444.13de0fd44849e3f7d780.js
---
old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/static/444.13de0fd44849e3f7d780.js
1970-01-01 01:00:00.000000000 +0100
+++
new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/static/444.13de0fd44849e3f7d780.js
2020-02-02 01:00:00.000000000 +0100
@@ -0,0 +1 @@
+"use
strict";(self.webpackChunk_jupyter_docprovider_extension=self.webpackChunk_jupyter_docprovider_extension||[]).push([[444],{444:(e,o,n)=>{n.r(o),n.d(o,{ICollaborativeContentProvider:()=>t,IGlobalAwareness:()=>a});var
r=n(262);const t=new
r.Token("@jupyter/collaboration-extension:ICollaborativeContentProvider"),a=new
r.Token("@jupyter/collaboration:IGlobalAwareness")}}]);
\ No newline at end of file
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn'
'--exclude=.svnignore'
old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/static/703.17b6b904d18a75a9f3c6.js
new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/static/703.17b6b904d18a75a9f3c6.js
---
old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/static/703.17b6b904d18a75a9f3c6.js
2020-02-02 01:00:00.000000000 +0100
+++
new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/static/703.17b6b904d18a75a9f3c6.js
1970-01-01 01:00:00.000000000 +0100
@@ -1 +0,0 @@
-"use
strict";(self.webpackChunk_jupyter_docprovider_extension=self.webpackChunk_jupyter_docprovider_extension||[]).push([[703],{703:(e,t,o)=>{o.r(t),o.d(t,{default:()=>D});var
r,a=o(180),n=o(123),i=o(256),s=o(920),l=o(295),d=o(243),c=o(343),u=o(977),p=o(227),v=o(624),g=o(0),h=o(236),b=o(132),w=o(672);!function(e){e.openPath="filebrowser:open-path"}(r||(r={}));const
m="api/collaboration/timeline",y="The file %1 has been opened with two
different views. This is not supported. Please close this view; otherwise, some
of your edits may not be saved
properly.",f={id:"@jupyter/docprovider-extension:drive",description:"The
default collaborative drive
provider",provides:h.ICollaborativeDrive,requires:[v.ITranslator],optional:[h.IGlobalAwareness],activate:(e,t,o)=>{const
r=t.load("jupyter_collaboration"),a=new
b.YDrive(e.serviceManager.user,r,o);return
e.serviceManager.contents.addDrive(a),a}},x={id:"@jupyter/docprovider-extension:yfile",description:"Plugin
to register the shared model factor
y for the content type
'file'",autoStart:!0,requires:[h.ICollaborativeDrive],optional:[],activate:(e,t)=>{t.sharedModelFactory.registerDocumentFactory("file",(()=>new
g.YFile))}},I={id:"@jupyter/docprovider-extension:ynotebook",description:"Plugin
to register the shared model factory for the content type
'notebook'",autoStart:!0,requires:[h.ICollaborativeDrive],optional:[p.ISettingRegistry],activate:(e,t,o)=>{let
r=!0;o&&o.load("@jupyterlab/notebook-extension:tracker").then((e=>{const
t=e=>{var t;const o=null==e?void
0:e.get("experimentalEnableDocumentWideUndoRedo").composite;r=null===(t=!o)||void
0===t||t};t(e),e.changed.connect((e=>t(e)))})),t.sharedModelFactory.registerDocumentFactory("notebook",(()=>new
g.YNotebook({disableDocumentWideUndoRedo:r})))}},k={id:"@jupyter/docprovider-extension:statusBarTimeline",description:"Plugin
to add a timeline slider to the status
bar",autoStart:!0,requires:[l.IStatusBar,h.ICollaborativeDrive],activate:async(e,t,o)=>{try{let
r=null,a=null;const
n=async(t,r)=>{if(r&&"RTC"===t.split(":")[0]&&o){t=t.slice(o.name.length+1),a&&(a.dispose(),a=null);const[n,s]=r.split(":"),l=o.providers.get(`${n}:${s}:${t}`),d=w.URLExt.join(e.serviceManager.serverSettings.baseUrl,m,t);a=new
b.TimelineWidget(d,l,l.contentType,l.format,m);const
c=document.getElementById("jp-slider-status-bar");c&&!a.isAttached&&i.Widget.attach(a,c)}};e.shell.currentChanged&&e.shell.currentChanged.connect((async(e,t)=>{const
o=t.newValue;a&&(a.dispose(),a=null),o&&"context"in o&&(await
o.context.ready,await
n(o.context.path,o.context.model.sharedModel.getState("document_id")))})),t&&(r||(r=new
i.Widget,r.addClass("jp-StatusBar-GroupItem"),r.addClass("jp-mod-highlighted"),r.id="jp-slider-status-bar",t.registerStatusItem("jp-slider-status-bar",{item:r,align:"left",rank:4,isActive:()=>{const
t=e.shell.currentWidget;if(t&&t.context&&"string"==typeof
t.context.path){const
e=t.context.path;return!!t.context.model.sharedModel.getState("document_id")&&"RTC"===e.split(":")[
0]}return!1}})))}catch(e){console.error("Failed to activate statusBarTimeline
plugin:",e)}}},_={id:"@jupyter/docprovider-extension:defaultFileBrowser",description:"The
default file browser factory
provider",provides:s.IDefaultFileBrowser,requires:[h.ICollaborativeDrive,s.IFileBrowserFactory],optional:[a.IRouter,a.JupyterFrontEnd.ITreeResolver,a.ILabShell,v.ITranslator],activate:async(e,t,o,r,a,n,i)=>{const{commands:s}=e,l=(null!=i?i:v.nullTranslator).load("jupyterlab");e.serviceManager.contents.addDrive(t);const
d=o.createFileBrowser("filebrowser",{auto:!1,restore:!1,driveName:t.name});return
d.node.setAttribute("role","region"),d.node.setAttribute("aria-label",l.__("File
Browser
Section")),C.restoreBrowser(d,s,r,a,n),d}},j={id:"@jupyter/docprovider-extension:logger",description:"A
logging plugin for debugging
purposes.",autoStart:!0,optional:[c.ILoggerRegistry,d.IEditorTracker,u.INotebookTracker,v.ITranslator],activate:(e,t,o,r,a)=>{const
i=(null!=a?a:v.nullTranslator).load("jupyte
r_collaboration"),s="https://schema.jupyter.org/jupyter_collaboration/session/v1";if(!t)return
void e.serviceManager.events.stream.connect(((e,t)=>{var
o,r;t.schema_id===s&&(console.debug(`[${t.room}(${t.path})]
${null!==(o=t.action)&&void 0!==o?o:""}: ${null!==(r=t.msg)&&void
0!==r?r:""}`),"WARNING"===t.level&&(0,n.showDialog)({title:i.__("Warning"),body:i.__(y,t.path),buttons:[n.Dialog.okButton()]}))}));const
l=new Map,d=(e,o)=>{const
r=t.getLogger(o.context.path);l.set(o.context.localPath,r),o.disposed.connect((e=>{l.delete(e.context.localPath)}))};o&&o.widgetAdded.connect(d),r&&r.widgetAdded.connect(d),(async()=>{var
t,o;const{events:r}=e.serviceManager;for await(const e of
r.stream)if(e.schema_id===s){const
r=l.get(e.path);null==r||r.log({type:"text",level:e.level.toLowerCase(),data:`[${e.room}]
${null!==(t=e.action)&&void 0!==t?t:""}: ${null!==(o=e.msg)&&void
0!==o?o:""}`}),"WARNING"===e.level&&(0,n.showDialog)({title:i.__("Warning"),body:i.__(y,e.path),buttons:[n.Dialog.warnB
utton({label:i.__("Ok")})]})}})()}};var C;!function(e){e.restoreBrowser=async
function(e,t,o,a,n){const i="jp-mod-restoring";if(e.addClass(i),!o)return await
e.model.restore(e.id),await e.model.refresh(),void e.removeClass(i);const
s=async()=>{o.routed.disconnect(s);const l=await(null==a?void
0:a.paths);(null==l?void 0:l.file)||(null==l?void 0:l.browser)?(await
e.model.restore(e.id,!1),l.file&&await
t.execute(r.openPath,{path:l.file,dontShowBrowser:!0}),l.browser&&await
t.execute(r.openPath,{path:l.browser,dontShowBrowser:!0})):(await
e.model.restore(e.id),await e.model.refresh()),e.removeClass(i),(null==n?void
0:n.isEmpty("main"))&&t.execute("launcher:create")};o.routed.connect(s)}}(C||(C={}));const
S={id:"@jupyter/docprovider-extension:notebook-cell-executor",description:"Add
notebook cell executor that uses REST API instead of kernel protocol over
WebSocket.",autoStart:!0,provides:u.INotebookCellExecutor,activate:e=>"true"===w.PageConfig.getOption("serverSideExecution")?new
b.Not
ebookCellServerExecutor({serverSettings:e.serviceManager.serverSettings}):Object.freeze({runCell:u.runCell})},T={id:"@jupyter/docprovider-extension:forkManager",autoStart:!0,requires:[h.ICollaborativeDrive],provides:b.IForkManagerToken,activate:(e,t)=>{const
o=e.serviceManager.events;return new
b.ForkManager({drive:t,eventManager:o})}},D=[f,x,I,_,j,S,k,T]}}]);
\ No newline at end of file
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn'
'--exclude=.svnignore'
old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/static/703.b02363b93dbf18450ce4.js
new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/static/703.b02363b93dbf18450ce4.js
---
old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/static/703.b02363b93dbf18450ce4.js
1970-01-01 01:00:00.000000000 +0100
+++
new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/static/703.b02363b93dbf18450ce4.js
2020-02-02 01:00:00.000000000 +0100
@@ -0,0 +1 @@
+"use
strict";(self.webpackChunk_jupyter_docprovider_extension=self.webpackChunk_jupyter_docprovider_extension||[]).push([[703],{703:(e,t,o)=>{o.r(t),o.d(t,{default:()=>k});var
r=o(569),n=o(256),i=o(319),a=o(739),s=o(191),l=o(369),d=o(507),c=o(579),u=o(0),v=o(980),p=o(772),g=o(808);const
h="api/collaboration/timeline",b="The file %1 has been opened with two
different views. This is not supported. Please close this view; otherwise, some
of your edits may not be saved
properly.",y={id:"@jupyter/docprovider-extension:content-provider",description:"The
RTC content
provider",provides:v.ICollaborativeContentProvider,requires:[c.ITranslator],optional:[v.IGlobalAwareness],activate:(e,t,o)=>{const
r=t.load("jupyter_collaboration"),n=e.serviceManager.contents.defaultDrive;if(!n)throw
Error("Cannot initialize content provider: default drive property not
accessible on contents manager instance.");const
i=n.contentProviderRegistry;if(!i)throw Error("Cannot initialize content
provider: no content
provider registry.");const a=new
p.RtcContentProvider({apiEndpoint:"/api/contents",serverSettings:n.serverSettings,user:e.serviceManager.user,trans:r,globalAwareness:o});return
i.register("rtc",a),a}},m={id:"@jupyter/docprovider-extension:yfile",description:"Plugin
to register the shared model factory for the content type
'file'",autoStart:!0,requires:[v.ICollaborativeContentProvider,a.IEditorWidgetFactory],activate:(e,t,o)=>{t.sharedModelFactory.registerDocumentFactory("file",(()=>new
u.YFile)),o.contentProviderId="rtc"}},f={id:"@jupyter/docprovider-extension:ynotebook",description:"Plugin
to register the shared model factory for the content type
'notebook'",autoStart:!0,requires:[v.ICollaborativeContentProvider,l.INotebookWidgetFactory],optional:[d.ISettingRegistry],activate:(e,t,o,r)=>{let
n=!0;r&&r.load("@jupyterlab/notebook-extension:tracker").then((e=>{const
t=e=>{var t;const o=null==e?void
0:e.get("experimentalEnableDocumentWideUndoRedo").composite;n=null===(t=!o)||void
0===t
||t};t(e),e.changed.connect((e=>t(e)))})),t.sharedModelFactory.registerDocumentFactory("notebook",(()=>new
u.YNotebook({disableDocumentWideUndoRedo:n}))),o.contentProviderId="rtc"}},w={id:"@jupyter/docprovider-extension:statusBarTimeline",description:"Plugin
to add a timeline slider to the status
bar",autoStart:!0,requires:[i.IStatusBar,v.ICollaborativeContentProvider],activate:async(e,t,o)=>{try{let
r=null,i=null;const
a=async(t,r)=>{if(!r)return;i&&(i.dispose(),i=null);const[a,s]=r.split(":"),l=o.providers.get(`${a}:${s}:${t}`);if(!l)return;const
d=l,c=g.URLExt.join(e.serviceManager.serverSettings.baseUrl,h,t);i=new
p.TimelineWidget(c,d,d.contentType,d.format,h);const
u=document.getElementById("jp-slider-status-bar");u&&!i.isAttached&&n.Widget.attach(i,u)};e.shell.currentChanged&&e.shell.currentChanged.connect((async(e,t)=>{const
o=t.newValue;i&&(i.dispose(),i=null),o&&"context"in o&&(await
o.context.ready,await
a(o.context.path,o.context.model.sharedModel.getState("document_id"))
)})),t&&(r||(r=new
n.Widget,r.addClass("jp-StatusBar-GroupItem"),r.addClass("jp-mod-highlighted"),r.id="jp-slider-status-bar",t.registerStatusItem("jp-slider-status-bar",{item:r,align:"left",rank:4,isActive:()=>{var
t,o;const r=e.shell.currentWidget;return(null===(o=null===(t=null==r?void
0:r.context)||void 0===t?void 0:t.model)||void 0===o?void
0:o.collaborative)||!1}})))}catch(e){console.error("Failed to activate
statusBarTimeline
plugin:",e)}}},k=[y,m,f,{id:"@jupyter/docprovider-extension:logger",description:"A
logging plugin for debugging
purposes.",autoStart:!0,optional:[s.ILoggerRegistry,a.IEditorTracker,l.INotebookTracker,c.ITranslator],activate:(e,t,o,n,i)=>{const
a=(null!=i?i:c.nullTranslator).load("jupyter_collaboration"),s="https://schema.jupyter.org/jupyter_collaboration/session/v1";if(!t)return
void e.serviceManager.events.stream.connect(((e,t)=>{var
o,n;t.schema_id===s&&(console.debug(`[${t.room}(${t.path})]
${null!==(o=t.action)&&void 0!==o?o:""}: ${null!==(n=t.msg)&&
void
0!==n?n:""}`),"WARNING"===t.level&&(0,r.showDialog)({title:a.__("Warning"),body:a.__(b,t.path),buttons:[r.Dialog.okButton()]}))}));const
l=new Map,d=(e,o)=>{const
r=t.getLogger(o.context.path);l.set(o.context.localPath,r),o.disposed.connect((e=>{l.delete(e.context.localPath)}))};o&&o.widgetAdded.connect(d),n&&n.widgetAdded.connect(d),(async()=>{var
t,o;const{events:n}=e.serviceManager;for await(const e of
n.stream)if(e.schema_id===s){const
n=l.get(e.path);null==n||n.log({type:"text",level:e.level.toLowerCase(),data:`[${e.room}]
${null!==(t=e.action)&&void 0!==t?t:""}: ${null!==(o=e.msg)&&void
0!==o?o:""}`}),"WARNING"===e.level&&(0,r.showDialog)({title:a.__("Warning"),body:a.__(b,e.path),buttons:[r.Dialog.warnButton({label:a.__("Ok")})]})}})()}},{id:"@jupyter/docprovider-extension:notebook-cell-executor",description:"Add
notebook cell executor that uses REST API instead of kernel protocol over
WebSocket.",autoStart:!0,provides:l.INotebookCellExecutor,activate:e=>"true"===g.PageC
onfig.getOption("serverSideExecution")?new
p.NotebookCellServerExecutor({serverSettings:e.serviceManager.serverSettings}):Object.freeze({runCell:l.runCell})},w,{id:"@jupyter/docprovider-extension:forkManager",autoStart:!0,requires:[v.ICollaborativeContentProvider],provides:p.IForkManagerToken,activate:(e,t)=>{const
o=e.serviceManager.events;return new
p.ForkManager({contentProvider:t,eventManager:o})}}]}}]);
\ No newline at end of file
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn'
'--exclude=.svnignore'
old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/static/944.b26f5029dcd72a4e58bc.js
new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/static/944.b26f5029dcd72a4e58bc.js
---
old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/static/944.b26f5029dcd72a4e58bc.js
1970-01-01 01:00:00.000000000 +0100
+++
new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/static/944.b26f5029dcd72a4e58bc.js
2020-02-02 01:00:00.000000000 +0100
@@ -0,0 +1 @@
+"use
strict";(self.webpackChunk_jupyter_docprovider_extension=self.webpackChunk_jupyter_docprovider_extension||[]).push([[944],{78:(n,e,o)=>{o.d(e,{A:()=>u});var
r=o(758),t=o.n(r),a=o(935),i=o.n(a),l=o(875),p=o(28),s=o(921),c=i()(t());c.i(l.A),c.i(p.A),c.i(s.A),c.push([n.id,"/*
-----------------------------------------------------------------------------\n|
Copyright (c) Jupyter Development Team.\n| Distributed under the terms of the
Modified BSD
License.\n|----------------------------------------------------------------------------
*/\n\n.jp-shared-link-body {\n user-select: none;\n}\n",""]);const
u=c},875:(n,e,o)=>{o.d(e,{A:()=>l});var
r=o(758),t=o.n(r),a=o(935),i=o.n(a)()(t());i.push([n.id,"/*
-----------------------------------------------------------------------------\n|
Copyright (c) Jupyter Development Team.\n| Distributed under the terms of the
Modified BSD
License.\n|----------------------------------------------------------------------------
*/\n\n.jp-MenuBar-label {\n
margin-left: 25px;\n}\n\n.jp-MenuBar-anonymousIcon span {\n width: 24px;\n
text-align: center;\n fill: var(--jp-ui-font-color1);\n color:
var(--jp-ui-font-color1);\n}\n\n.jp-MenuBar-anonymousIcon,\n.jp-MenuBar-imageIcon
{\n position: absolute;\n top: 1px;\n left: 8px;\n width: 24px;\n height:
24px;\n display: flex;\n align-items: center;\n vertical-align: middle;\n
border-radius: 100%;\n}\n\n.jp-MenuBar-imageIcon img {\n width: 24px;\n
border-radius: 100%;\n fill: var(--jp-ui-font-color1);\n color:
var(--jp-ui-font-color1);\n}\n\n.jp-UserMenu-caretDownIcon {\n height: 22px;\n
position: relative;\n top: 15%;\n}\n",""]);const
l=i},28:(n,e,o)=>{o.d(e,{A:()=>l});var
r=o(758),t=o.n(r),a=o(935),i=o.n(a)()(t());i.push([n.id,"/*\n * Copyright (c)
Jupyter Development Team.\n * Distributed under the terms of the Modified BSD
License.\n
*/\n\n/************************************************************\n
Main Panel\n***********************************
**************************/\n\n.jp-RTCPanel {\n min-width:
var(--jp-sidebar-min-width) !important;\n color: var(--jp-ui-font-color1);\n
background: var(--jp-layout-color1);\n font-size:
var(--jp-ui-font-size1);\n}\n\n/************************************************************\n
User Info
Panel\n*************************************************************/\n.jp-UserInfoPanel
{\n display: flex;\n flex-direction: column;\n max-height: 140px;\n
padding-top: 3px;\n}\n\n.jp-UserInfo-Container {\n margin: 20px;\n display:
flex;\n flex-direction: column;\n align-items:
center;\n}\n\n.jp-UserInfo-Icon {\n margin: auto;\n width: 50px;\n height:
50px;\n border-radius: 50px;\n display: inline-flex;\n align-items:
center;\n}\n\n.jp-UserInfo-Icon span {\n margin: auto;\n text-align:
center;\n font-size: 25px;\n fill: var(--jp-ui-font-color1);\n color:
var(--jp-ui-font-color1);\n}\n\n.jp-UserInfo-Info {\n margin: 20px;\n
display: inline-flex;\n fle
x-direction: column;\n}\n\n.jp-UserInfo-Info label {\n font-weight: bold;\n
fill: var(--jp-ui-font-color1);\n color:
var(--jp-ui-font-color1);\n}\n\n.jp-UserInfo-Info input {\n text-decoration:
none;\n border-top: none;\n border-left: none;\n border-right: none;\n
border-color: var(--jp-ui-font-color1);\n border-width: 0.5px;\n
background-color: transparent;\n fill: var(--jp-ui-font-color1);\n color:
var(--jp-ui-font-color1);\n}\n\n/************************************************************\n
Collaborators Info
Panel\n*************************************************************/\n\n.jp-CollaboratorsPanel
{\n overflow-y: auto;\n}\n\n.jp-CollaboratorsList {\n flex-direction:
column;\n display: flex;\n z-index: 1000;\n}\n\n.jp-CollaboratorHeader {\n
padding: 10px;\n display: flex;\n align-items: center;\n font-size:
var(--jp-ui-font-size0);\n fill: var(--jp-ui-font-color1);\n color:
var(--jp-ui-font-color1);\n}\n\n.jp-CollaboratorHeader > span {\
n padding-left: 7px;\n}\n\n.jp-ClickableCollaborator:hover {\n cursor:
pointer;\n background-color: var(--jp-layout-color2);\n fill:
var(--jp-ui-font-color0);\n color:
var(--jp-ui-font-color0);\n}\n\n.jp-CollaboratorHeaderCollapser {\n transform:
rotate(-90deg);\n margin: auto 0;\n height:
16px;\n}\n\n.jp-CollaboratorHeader:not(.jp-ClickableCollaborator)
.jp-CollaboratorHeaderCollapser {\n visibility:
hidden;\n}\n\n.jp-CollaboratorHeaderCollapser.jp-mod-expanded {\n transform:
rotate(0deg);\n}\n\n.jp-CollaboratorIcon {\n border-radius: 100%;\n padding:
2px;\n width: 24px;\n height: 24px;\n display:
flex;\n}\n\n.jp-CollaboratorIcon > span {\n text-align: center;\n margin:
auto;\n font-size: 12px;\n fill: var(--jp-ui-font-color1);\n color:
var(--jp-ui-font-color1);\n}\n\n.jp-CollaboratorFiles {\n padding-left: 1em;\n
margin-top: 0;\n box-shadow: 0 2px 2px -2px rgb(0 0 0 /
24%);\n\n}\n",""]);const l=i},921:(n,e,o)=>{o.d(e,{A:()=>l});var
r=o(758),t=o.n(r),a=o(935)
,i=o.n(a)()(t());i.push([n.id,"/*
-----------------------------------------------------------------------------\n|
Copyright (c) Jupyter Development Team.\n| Distributed under the terms of the
Modified BSD
License.\n|----------------------------------------------------------------------------
*/\n\n.jp-toolbar-users-item {\n flex-grow: 1;\n display: flex;\n
flex-direction: row;\n}\n\n.jp-toolbar-users-item
.jp-MenuBar-anonymousIcon,\n.jp-toolbar-users-item .jp-MenuBar-imageIcon {\n
position: relative;\n left: 0;\n height: 22px;\n width: 22px;\n box-sizing:
border-box;\n cursor: default;\n}\n",""]);const
l=i},935:n=>{n.exports=function(n){var e=[];return e.toString=function(){return
this.map((function(e){var o="",r=void 0!==e[5];return e[4]&&(o+="@supports
(".concat(e[4],") {")),e[2]&&(o+="@media ".concat(e[2],"
{")),r&&(o+="@layer".concat(e[5].length>0?" ".concat(e[5]):"","
{")),o+=n(e),r&&(o+="}"),e[2]&&(o+="}"),e[4]&&(o+="}"),o})).join("")},e.i=function(n,o,r,t,a){"string
"==typeof n&&(n=[[null,n,void 0]]);var i={};if(r)for(var
l=0;l<this.length;l++){var p=this[l][0];null!=p&&(i[p]=!0)}for(var
s=0;s<n.length;s++){var c=[].concat(n[s]);r&&i[c[0]]||(void 0!==a&&(void
0===c[5]||(c[1]="@layer".concat(c[5].length>0?" ".concat(c[5]):"","
{").concat(c[1],"}")),c[5]=a),o&&(c[2]?(c[1]="@media ".concat(c[2],"
{").concat(c[1],"}"),c[2]=o):c[2]=o),t&&(c[4]?(c[1]="@supports
(".concat(c[4],")
{").concat(c[1],"}"),c[4]=t):c[4]="".concat(t)),e.push(c))}},e}},758:n=>{n.exports=function(n){return
n[1]}},591:n=>{var e=[];function o(n){for(var
o=-1,r=0;r<e.length;r++)if(e[r].identifier===n){o=r;break}return o}function
r(n,r){for(var a={},i=[],l=0;l<n.length;l++){var
p=n[l],s=r.base?p[0]+r.base:p[0],c=a[s]||0,u="".concat(s,"
").concat(c);a[s]=c+1;var
d=o(u),f={css:p[1],media:p[2],sourceMap:p[3],supports:p[4],layer:p[5]};if(-1!==d)e[d].references++,e[d].updater(f);else{var
m=t(f,r);r.byIndex=l,e.splice(l,0,{identifier:u,updater:m,references:1})}i.push(u)}return
i}function
t(n,e){var o=e.domAPI(e);return
o.update(n),function(e){if(e){if(e.css===n.css&&e.media===n.media&&e.sourceMap===n.sourceMap&&e.supports===n.supports&&e.layer===n.layer)return;o.update(n=e)}else
o.remove()}}n.exports=function(n,t){var a=r(n=n||[],t=t||{});return
function(n){n=n||[];for(var i=0;i<a.length;i++){var
l=o(a[i]);e[l].references--}for(var p=r(n,t),s=0;s<a.length;s++){var
c=o(a[s]);0===e[c].references&&(e[c].updater(),e.splice(c,1))}a=p}}},128:n=>{var
e={};n.exports=function(n,o){var r=function(n){if(void 0===e[n]){var
o=document.querySelector(n);if(window.HTMLIFrameElement&&o instanceof
window.HTMLIFrameElement)try{o=o.contentDocument.head}catch(n){o=null}e[n]=o}return
e[n]}(n);if(!r)throw new Error("Couldn't find a style target. This probably
means that the value for the 'insert' parameter is
invalid.");r.appendChild(o)}},51:n=>{n.exports=function(n){var
e=document.createElement("style");return
n.setAttributes(e,n.attributes),n.insert(e,n.options),e}},855:(n,e,o)=>{n.exp
orts=function(n){var
e=o.nc;e&&n.setAttribute("nonce",e)}},359:n=>{n.exports=function(n){if("undefined"==typeof
document)return{update:function(){},remove:function(){}};var
e=n.insertStyleElement(n);return{update:function(o){!function(n,e,o){var
r="";o.supports&&(r+="@supports (".concat(o.supports,")
{")),o.media&&(r+="@media ".concat(o.media," {"));var t=void
0!==o.layer;t&&(r+="@layer".concat(o.layer.length>0?" ".concat(o.layer):"","
{")),r+=o.css,t&&(r+="}"),o.media&&(r+="}"),o.supports&&(r+="}");var
a=o.sourceMap;a&&"undefined"!=typeof btoa&&(r+="\n/*#
sourceMappingURL=data:application/json;base64,".concat(btoa(unescape(encodeURIComponent(JSON.stringify(a)))),"
*/")),e.styleTagTransform(r,n,e.options)}(e,n,o)},remove:function(){!function(n){if(null===n.parentNode)return!1;n.parentNode.removeChild(n)}(e)}}}},656:n=>{n.exports=function(n,e){if(e.styleSheet)e.styleSheet.cssText=n;else{for(;e.firstChild;)e.removeChild(e.firstChild);e.appendChild(document.createTextNode(n))}}},944:(n
,e,o)=>{var
r=o(591),t=o.n(r),a=o(359),i=o.n(a),l=o(128),p=o.n(l),s=o(855),c=o.n(s),u=o(51),d=o.n(u),f=o(656),m=o.n(f),v=o(78),h={};h.styleTagTransform=m(),h.setAttributes=c(),h.insert=p().bind(null,"head"),h.domAPI=i(),h.insertStyleElement=d(),t()(v.A,h),v.A&&v.A.locals&&v.A.locals}}]);
\ No newline at end of file
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn'
'--exclude=.svnignore'
old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/static/944.b85c55dff0f14165f872.js
new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/static/944.b85c55dff0f14165f872.js
---
old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/static/944.b85c55dff0f14165f872.js
2020-02-02 01:00:00.000000000 +0100
+++
new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/static/944.b85c55dff0f14165f872.js
1970-01-01 01:00:00.000000000 +0100
@@ -1 +0,0 @@
-"use
strict";(self.webpackChunk_jupyter_docprovider_extension=self.webpackChunk_jupyter_docprovider_extension||[]).push([[944],{78:(n,e,o)=>{o.d(e,{A:()=>s});var
r=o(758),t=o.n(r),a=o(935),i=o.n(a),l=o(875),p=o(28),c=i()(t());c.i(l.A),c.i(p.A),c.push([n.id,"/*
-----------------------------------------------------------------------------\n|
Copyright (c) Jupyter Development Team.\n| Distributed under the terms of the
Modified BSD
License.\n|----------------------------------------------------------------------------
*/\n\n.jp-shared-link-body {\n user-select: none;\n}\n",""]);const
s=c},875:(n,e,o)=>{o.d(e,{A:()=>l});var
r=o(758),t=o.n(r),a=o(935),i=o.n(a)()(t());i.push([n.id,"/*
-----------------------------------------------------------------------------\n|
Copyright (c) Jupyter Development Team.\n| Distributed under the terms of the
Modified BSD
License.\n|----------------------------------------------------------------------------
*/\n\n.jp-MenuBar-label {\n margin-left: 25px
;\n}\n\n.jp-MenuBar-anonymousIcon span {\n width: 24px;\n text-align:
center;\n fill: var(--jp-ui-font-color1);\n color:
var(--jp-ui-font-color1);\n}\n\n.jp-MenuBar-anonymousIcon,\n.jp-MenuBar-imageIcon
{\n position: absolute;\n top: 1px;\n left: 8px;\n width: 24px;\n height:
24px;\n display: flex;\n align-items: center;\n vertical-align: middle;\n
border-radius: 100%;\n}\n\n.jp-MenuBar-imageIcon img {\n width: 24px;\n
border-radius: 100%;\n fill: var(--jp-ui-font-color1);\n color:
var(--jp-ui-font-color1);\n}\n\n.jp-UserMenu-caretDownIcon {\n height: 22px;\n
position: relative;\n top: 15%;\n}\n",""]);const
l=i},28:(n,e,o)=>{o.d(e,{A:()=>l});var
r=o(758),t=o.n(r),a=o(935),i=o.n(a)()(t());i.push([n.id,"/*\n * Copyright (c)
Jupyter Development Team.\n * Distributed under the terms of the Modified BSD
License.\n
*/\n\n/************************************************************\n
Main Panel\n*****************************************************
********/\n\n.jp-RTCPanel {\n min-width: var(--jp-sidebar-min-width)
!important;\n color: var(--jp-ui-font-color1);\n background:
var(--jp-layout-color1);\n font-size:
var(--jp-ui-font-size1);\n}\n\n/************************************************************\n
User Info
Panel\n*************************************************************/\n.jp-UserInfoPanel
{\n display: flex;\n flex-direction: column;\n max-height: 140px;\n
padding-top: 3px;\n}\n\n.jp-UserInfo-Container {\n margin: 20px;\n display:
flex;\n flex-direction: column;\n align-items:
center;\n}\n\n.jp-UserInfo-Icon {\n margin: auto;\n width: 50px;\n height:
50px;\n border-radius: 50px;\n display: inline-flex;\n align-items:
center;\n}\n\n.jp-UserInfo-Icon span {\n margin: auto;\n text-align:
center;\n font-size: 25px;\n fill: var(--jp-ui-font-color1);\n color:
var(--jp-ui-font-color1);\n}\n\n.jp-UserInfo-Info {\n margin: 20px;\n
display: inline-flex;\n flex-direction: colum
n;\n}\n\n.jp-UserInfo-Info label {\n font-weight: bold;\n fill:
var(--jp-ui-font-color1);\n color:
var(--jp-ui-font-color1);\n}\n\n.jp-UserInfo-Info input {\n text-decoration:
none;\n border-top: none;\n border-left: none;\n border-right: none;\n
border-color: var(--jp-ui-font-color1);\n border-width: 0.5px;\n
background-color: transparent;\n fill: var(--jp-ui-font-color1);\n color:
var(--jp-ui-font-color1);\n}\n\n/************************************************************\n
Collaborators Info
Panel\n*************************************************************/\n\n.jp-CollaboratorsPanel
{\n overflow-y: auto;\n}\n\n.jp-CollaboratorsList {\n flex-direction:
column;\n display: flex;\n z-index: 1000;\n}\n\n.jp-CollaboratorHeader {\n
padding: 10px;\n display: flex;\n align-items: center;\n font-size:
var(--jp-ui-font-size0);\n fill: var(--jp-ui-font-color1);\n color:
var(--jp-ui-font-color1);\n}\n\n.jp-CollaboratorHeader > span {\n
padding-left: 7
px;\n}\n\n.jp-ClickableCollaborator:hover {\n cursor: pointer;\n
background-color: var(--jp-layout-color2);\n fill: var(--jp-ui-font-color0);\n
color: var(--jp-ui-font-color0);\n}\n\n.jp-CollaboratorHeaderCollapser {\n
transform: rotate(-90deg);\n margin: auto 0;\n height:
16px;\n}\n\n.jp-CollaboratorHeader:not(.jp-ClickableCollaborator)
.jp-CollaboratorHeaderCollapser {\n visibility:
hidden;\n}\n\n.jp-CollaboratorHeaderCollapser.jp-mod-expanded {\n transform:
rotate(0deg);\n}\n\n.jp-CollaboratorIcon {\n border-radius: 100%;\n padding:
2px;\n width: 24px;\n height: 24px;\n display:
flex;\n}\n\n.jp-CollaboratorIcon > span {\n text-align: center;\n margin:
auto;\n font-size: 12px;\n fill: var(--jp-ui-font-color1);\n color:
var(--jp-ui-font-color1);\n}\n\n.jp-CollaboratorFiles {\n padding-left: 1em;\n
margin-top: 0;\n box-shadow: 0 2px 2px -2px rgb(0 0 0 /
24%);\n\n}\n",""]);const l=i},935:n=>{n.exports=function(n){var e=[];return
e.toString=function(){return this
.map((function(e){var o="",r=void 0!==e[5];return e[4]&&(o+="@supports
(".concat(e[4],") {")),e[2]&&(o+="@media ".concat(e[2],"
{")),r&&(o+="@layer".concat(e[5].length>0?" ".concat(e[5]):"","
{")),o+=n(e),r&&(o+="}"),e[2]&&(o+="}"),e[4]&&(o+="}"),o})).join("")},e.i=function(n,o,r,t,a){"string"==typeof
n&&(n=[[null,n,void 0]]);var i={};if(r)for(var l=0;l<this.length;l++){var
p=this[l][0];null!=p&&(i[p]=!0)}for(var c=0;c<n.length;c++){var
s=[].concat(n[c]);r&&i[s[0]]||(void 0!==a&&(void
0===s[5]||(s[1]="@layer".concat(s[5].length>0?" ".concat(s[5]):"","
{").concat(s[1],"}")),s[5]=a),o&&(s[2]?(s[1]="@media ".concat(s[2],"
{").concat(s[1],"}"),s[2]=o):s[2]=o),t&&(s[4]?(s[1]="@supports
(".concat(s[4],")
{").concat(s[1],"}"),s[4]=t):s[4]="".concat(t)),e.push(s))}},e}},758:n=>{n.exports=function(n){return
n[1]}},591:n=>{var e=[];function o(n){for(var
o=-1,r=0;r<e.length;r++)if(e[r].identifier===n){o=r;break}return o}function
r(n,r){for(var a={},i=[],l=0;l<n.length;l++){var p=n[l],c=r.base?
p[0]+r.base:p[0],s=a[c]||0,u="".concat(c," ").concat(s);a[c]=s+1;var
d=o(u),f={css:p[1],media:p[2],sourceMap:p[3],supports:p[4],layer:p[5]};if(-1!==d)e[d].references++,e[d].updater(f);else{var
v=t(f,r);r.byIndex=l,e.splice(l,0,{identifier:u,updater:v,references:1})}i.push(u)}return
i}function t(n,e){var o=e.domAPI(e);return
o.update(n),function(e){if(e){if(e.css===n.css&&e.media===n.media&&e.sourceMap===n.sourceMap&&e.supports===n.supports&&e.layer===n.layer)return;o.update(n=e)}else
o.remove()}}n.exports=function(n,t){var a=r(n=n||[],t=t||{});return
function(n){n=n||[];for(var i=0;i<a.length;i++){var
l=o(a[i]);e[l].references--}for(var p=r(n,t),c=0;c<a.length;c++){var
s=o(a[c]);0===e[s].references&&(e[s].updater(),e.splice(s,1))}a=p}}},128:n=>{var
e={};n.exports=function(n,o){var r=function(n){if(void 0===e[n]){var
o=document.querySelector(n);if(window.HTMLIFrameElement&&o instanceof
window.HTMLIFrameElement)try{o=o.contentDocument.head}catch(n){o=null}e[n]=o}return
e[n]}(n);if(!r)
throw new Error("Couldn't find a style target. This probably means that the
value for the 'insert' parameter is
invalid.");r.appendChild(o)}},51:n=>{n.exports=function(n){var
e=document.createElement("style");return
n.setAttributes(e,n.attributes),n.insert(e,n.options),e}},855:(n,e,o)=>{n.exports=function(n){var
e=o.nc;e&&n.setAttribute("nonce",e)}},740:n=>{n.exports=function(n){if("undefined"==typeof
document)return{update:function(){},remove:function(){}};var
e=n.insertStyleElement(n);return{update:function(o){!function(n,e,o){var
r="";o.supports&&(r+="@supports (".concat(o.supports,")
{")),o.media&&(r+="@media ".concat(o.media," {"));var t=void
0!==o.layer;t&&(r+="@layer".concat(o.layer.length>0?" ".concat(o.layer):"","
{")),r+=o.css,t&&(r+="}"),o.media&&(r+="}"),o.supports&&(r+="}");var
a=o.sourceMap;a&&"undefined"!=typeof btoa&&(r+="\n/*#
sourceMappingURL=data:application/json;base64,".concat(btoa(unescape(encodeURIComponent(JSON.stringify(a)))),"
*/")),e.styleTagTransform(r,n,
e.options)}(e,n,o)},remove:function(){!function(n){if(null===n.parentNode)return!1;n.parentNode.removeChild(n)}(e)}}}},656:n=>{n.exports=function(n,e){if(e.styleSheet)e.styleSheet.cssText=n;else{for(;e.firstChild;)e.removeChild(e.firstChild);e.appendChild(document.createTextNode(n))}}},944:(n,e,o)=>{var
r=o(591),t=o.n(r),a=o(740),i=o.n(a),l=o(128),p=o.n(l),c=o(855),s=o.n(c),u=o(51),d=o.n(u),f=o(656),v=o.n(f),m=o(78),h={};h.styleTagTransform=v(),h.setAttributes=s(),h.insert=p().bind(null,"head"),h.domAPI=i(),h.insertStyleElement=d(),t()(m.A,h),m.A&&m.A.locals&&m.A.locals}}]);
\ No newline at end of file
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn'
'--exclude=.svnignore'
old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/static/remoteEntry.236b886ba495f686c573.js
new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/static/remoteEntry.236b886ba495f686c573.js
---
old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/static/remoteEntry.236b886ba495f686c573.js
1970-01-01 01:00:00.000000000 +0100
+++
new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/static/remoteEntry.236b886ba495f686c573.js
2020-02-02 01:00:00.000000000 +0100
@@ -0,0 +1 @@
+var _JUPYTERLAB;(()=>{"use strict";var
e,r,t,o,n,a,i,l,u,s,d,f,c,p,v,h,y,m,b,g,j,w,P,S={496:(e,r,t)=>{var
o={"./index":()=>Promise.all([t.e(738),t.e(453),t.e(703)]).then((()=>()=>t(703))),"./extension":()=>Promise.all([t.e(738),t.e(453),t.e(703)]).then((()=>()=>t(703))),"./style":()=>t.e(944).then((()=>()=>t(944)))},n=(e,r)=>(t.R=r,r=t.o(o,e)?o[e]():Promise.resolve().then((()=>{throw
new Error('Module "'+e+'" does not exist in container.')})),t.R=void
0,r),a=(e,r)=>{if(t.S){var o="default",n=t.S[o];if(n&&n!==e)throw new
Error("Container initialization failed as it has already been initialized with
a different share scope");return
t.S[o]=e,t.I(o,r)}};t.d(r,{get:()=>n,init:()=>a})}},k={};function x(e){var
r=k[e];if(void 0!==r)return r.exports;var t=k[e]={id:e,exports:{}};return
S[e](t,t.exports,x),t.exports}x.m=S,x.c=k,x.n=e=>{var
r=e&&e.__esModule?()=>e.default:()=>e;return
x.d(r,{a:r}),r},x.d=(e,r)=>{for(var t in
r)x.o(r,t)&&!x.o(e,t)&&Object.defineProperty(e,t,{enumerable:!0,get:r[
t]})},x.f={},x.e=e=>Promise.all(Object.keys(x.f).reduce(((r,t)=>(x.f[t](e,r),r)),[])),x.u=e=>e+"."+{240:"b89bafe21cc031ed1f8d",444:"13de0fd44849e3f7d780",576:"21a3c1a9ebaebb58d346",703:"b02363b93dbf18450ce4",944:"b26f5029dcd72a4e58bc"}[e]+".js?v="+{240:"b89bafe21cc031ed1f8d",444:"13de0fd44849e3f7d780",576:"21a3c1a9ebaebb58d346",703:"b02363b93dbf18450ce4",944:"b26f5029dcd72a4e58bc"}[e],x.g=function(){if("object"==typeof
globalThis)return globalThis;try{return this||new Function("return
this")()}catch(e){if("object"==typeof window)return
window}}(),x.o=(e,r)=>Object.prototype.hasOwnProperty.call(e,r),e={},r="@jupyter/docprovider-extension:",x.l=(t,o,n,a)=>{if(e[t])e[t].push(o);else{var
i,l;if(void 0!==n)for(var
u=document.getElementsByTagName("script"),s=0;s<u.length;s++){var
d=u[s];if(d.getAttribute("src")==t||d.getAttribute("data-webpack")==r+n){i=d;break}}i||(l=!0,(i=document.createElement("script")).charset="utf-8",i.timeout=120,x.nc&&i.setAttribute("nonce",x.nc),i.setAttribute("d
ata-webpack",r+n),i.src=t),e[t]=[o];var
f=(r,o)=>{i.onerror=i.onload=null,clearTimeout(c);var n=e[t];if(delete
e[t],i.parentNode&&i.parentNode.removeChild(i),n&&n.forEach((e=>e(o))),r)return
r(o)},c=setTimeout(f.bind(null,void
0,{type:"timeout",target:i}),12e4);i.onerror=f.bind(null,i.onerror),i.onload=f.bind(null,i.onload),l&&document.head.appendChild(i)}},x.r=e=>{"undefined"!=typeof
Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},(()=>{x.S={};var
e={},r={};x.I=(t,o)=>{o||(o=[]);var
n=r[t];if(n||(n=r[t]={}),!(o.indexOf(n)>=0)){if(o.push(n),e[t])return
e[t];x.o(x.S,t)||(x.S[t]={});var
a=x.S[t],i="@jupyter/docprovider-extension",l=(e,r,t,o)=>{var
n=a[e]=a[e]||{},l=n[r];(!l||!l.loaded&&(!o!=!l.eager?o:i>l.from))&&(n[r]={get:t,from:i,eager:!!o})},u=[];return"default"===t&&(l("@jupyter/collaborative-drive","4.0.2",(()=>Promise.all([x.e(262),x.e(444)]).then((()=>()=>x(444))))),l("@jupyter/docprovid
er-extension","4.0.2",(()=>Promise.all([x.e(738),x.e(453),x.e(703)]).then((()=>()=>x(703))))),l("@jupyter/docprovider","4.0.2",(()=>Promise.all([x.e(738),x.e(262),x.e(240)]).then((()=>()=>x(240))))),l("y-websocket","1.5.4",(()=>Promise.all([x.e(576),x.e(206)]).then((()=>()=>x(576)))))),e[t]=u.length?Promise.all(u).then((()=>e[t]=1)):1}}})(),(()=>{var
e;x.g.importScripts&&(e=x.g.location+"");var
r=x.g.document;if(!e&&r&&(r.currentScript&&"SCRIPT"===r.currentScript.tagName.toUpperCase()&&(e=r.currentScript.src),!e)){var
t=r.getElementsByTagName("script");if(t.length)for(var
o=t.length-1;o>-1&&(!e||!/^http(s?):/.test(e));)e=t[o--].src}if(!e)throw new
Error("Automatic publicPath is not supported in this
browser");e=e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),x.p=e})(),t=e=>{var
r=e=>e.split(".").map((e=>+e==e?+e:e)),t=/^([^-+]+)?(?:-([^+]+))?(?:\+(.+))?$/.exec(e),o=t[1]?r(t[1]):[];return
t[2]&&(o.length++,o.push.apply(o,r(t[2]))),t[3]&&(o.push([]),o.push.apply(o,r(
t[3]))),o},o=(e,r)=>{e=t(e),r=t(r);for(var o=0;;){if(o>=e.length)return
o<r.length&&"u"!=(typeof r[o])[0];var n=e[o],a=(typeof
n)[0];if(o>=r.length)return"u"==a;var i=r[o],l=(typeof
i)[0];if(a!=l)return"o"==a&&"n"==l||"s"==l||"u"==a;if("o"!=a&&"u"!=a&&n!=i)return
n<i;o++}},n=e=>{var
r=e[0],t="";if(1===e.length)return"*";if(r+.5){t+=0==r?">=":-1==r?"<":1==r?"^":2==r?"~":r>0?"=":"!=";for(var
o=1,a=1;a<e.length;a++)o--,t+="u"==(typeof(l=e[a]))[0]?"-":(o>0?".":"")+(o=2,l);return
t}var i=[];for(a=1;a<e.length;a++){var
l=e[a];i.push(0===l?"not("+u()+")":1===l?"("+u()+" || "+u()+")":2===l?i.pop()+"
"+i.pop():n(l))}return u();function u(){return
i.pop().replace(/^\((.+)\)$/,"$1")}},a=(e,r)=>{if(0 in e){r=t(r);var
o=e[0],n=o<0;n&&(o=-o-1);for(var i=0,l=1,u=!0;;l++,i++){var
s,d,f=l<e.length?(typeof
e[l])[0]:"";if(i>=r.length||"o"==(d=(typeof(s=r[i]))[0]))return!u||("u"==f?l>o&&!n:""==f!=n);if("u"==d){if(!u||"u"!=f)return!1}else
if(u)if(f==d)if(l<=o){if(s!=e[l])return!1}else{if(n?s>e[l]:s<e[l]
)return!1;s!=e[l]&&(u=!1)}else
if("s"!=f&&"n"!=f){if(n||l<=o)return!1;u=!1,l--}else{if(l<=o||d<f!=n)return!1;u=!1}else"s"!=f&&"n"!=f&&(u=!1,l--)}}var
c=[],p=c.pop.bind(c);for(i=1;i<e.length;i++){var
v=e[i];c.push(1==v?p()|p():2==v?p()&p():v?a(v,r):!p())}return!!p()},i=(e,r)=>e&&x.o(e,r),l=e=>(e.loaded=1,e.get()),u=e=>Object.keys(e).reduce(((r,t)=>(e[t].eager&&(r[t]=e[t]),r)),{}),s=(e,r,t,n)=>{var
i=n?u(e[r]):e[r];return(r=Object.keys(i).reduce(((e,r)=>!a(t,r)||e&&!o(e,r)?e:r),0))&&i[r]},d=(e,r,t)=>{var
n=t?u(e[r]):e[r];return
Object.keys(n).reduce(((e,r)=>!e||!n[e].loaded&&o(e,r)?r:e),0)},f=(e,r,t,o)=>"Unsatisfied
version "+t+" from "+(t&&e[r][t].from)+" of shared singleton module "+r+"
(required "+n(o)+")",c=(e,r,t,o,a)=>{var i=e[t];return"No satisfying version
("+n(o)+")"+(a?" for eager consumption":"")+" of shared module "+t+" found in
shared scope "+r+".\nAvailable versions: "+Object.keys(i).map((e=>e+" from
"+i[e].from)).join(", ")},p=e=>{throw new Error(e)},v=e=>{"undefined"!=
typeof
console&&console.warn&&console.warn(e)},y=(e,r,t)=>t?t():((e,r)=>p("Shared
module "+r+" doesn't exist in shared scope
"+e))(e,r),m=(h=e=>function(r,t,o,n,a){var i=x.I(r);return
i&&i.then&&!o?i.then(e.bind(e,r,x.S[r],t,!1,n,a)):e(r,x.S[r],t,o,n,a)})(((e,r,t,o,n,a)=>{if(!i(r,t))return
y(e,t,a);var u=s(r,t,n,o);return u?l(u):a?a():void
p(c(r,e,t,n,o))})),b=h(((e,r,t,o,n,u)=>{if(!i(r,t))return y(e,t,u);var
s=d(r,t,o);return
a(n,s)||v(f(r,t,s,n)),l(r[t][s])})),g={},j={569:()=>b("default","@jupyterlab/apputils",!1,[1,4,5,0]),579:()=>b("default","@jupyterlab/translation",!1,[1,4,4,0]),808:()=>b("default","@jupyterlab/coreutils",!1,[1,6,4,0]),0:()=>b("default","@jupyter/ydoc",!1,[1,3,0,0,,"a3"]),191:()=>b("default","@jupyterlab/logconsole",!1,[1,4,4,0]),256:()=>b("default","@lumino/widgets",!1,[1,2,3,1,,"alpha",0]),319:()=>b("default","@jupyterlab/statusbar",!1,[1,4,4,0]),369:()=>b("default","@jupyterlab/notebook",!1,[1,4,4,0]),507:()=>b("default","@jupyterlab/settingregistry",!1,[1,
4,4,0]),739:()=>b("default","@jupyterlab/fileeditor",!1,[1,4,4,0]),772:()=>b("default","@jupyter/docprovider",!1,[1,4,0,2],(()=>Promise.all([x.e(262),x.e(240)]).then((()=>()=>x(240))))),980:()=>b("default","@jupyter/collaborative-drive",!1,[1,4,0,2],(()=>Promise.all([x.e(262),x.e(444)]).then((()=>()=>x(444))))),262:()=>b("default","@lumino/coreutils",!1,[1,2,0,0]),345:()=>b("default","react",!1,[1,18,2,0]),560:()=>m("default","y-websocket",!1,[1,1,3,15],(()=>Promise.all([x.e(576),x.e(206)]).then((()=>()=>x(576))))),602:()=>b("default","@lumino/signaling",!1,[1,2,0,0]),695:()=>b("default","@jupyterlab/services",!1,[1,7,4,0]),989:()=>b("default","@jupyterlab/ui-components",!1,[1,4,4,0]),206:()=>b("default","yjs",!1,[1,13,5,40])},w={206:[206],240:[345,560,602,695,989],262:[262],453:[0,191,256,319,369,507,739,772,980],738:[569,579,808]},P={},x.f.consumes=(e,r)=>{x.o(w,e)&&w[e].forEach((e=>{if(x.o(g,e))return
r.push(g[e]);if(!P[e]){var t=r=>{g[e]=0,x.m[e]=t=>{delete x.c[e],t.exports=r()}
};P[e]=!0;var o=r=>{delete g[e],x.m[e]=t=>{throw delete x.c[e],r}};try{var
n=j[e]();n.then?r.push(g[e]=n.then(t).catch(o)):t(n)}catch(e){o(e)}}}))},(()=>{var
e={552:0};x.f.j=(r,t)=>{var o=x.o(e,r)?e[r]:void
0;if(0!==o)if(o)t.push(o[2]);else
if(/^(206|262|453|738)$/.test(r))e[r]=0;else{var n=new
Promise(((t,n)=>o=e[r]=[t,n]));t.push(o[2]=n);var a=x.p+x.u(r),i=new
Error;x.l(a,(t=>{if(x.o(e,r)&&(0!==(o=e[r])&&(e[r]=void 0),o)){var
n=t&&("load"===t.type?"missing":t.type),a=t&&t.target&&t.target.src;i.message="Loading
chunk "+r+" failed.\n("+n+":
"+a+")",i.name="ChunkLoadError",i.type=n,i.request=a,o[1](i)}}),"chunk-"+r,r)}};var
r=(r,t)=>{var o,n,[a,i,l]=t,u=0;if(a.some((r=>0!==e[r]))){for(o in
i)x.o(i,o)&&(x.m[o]=i[o]);l&&l(x)}for(r&&r(t);u<a.length;u++)n=a[u],x.o(e,n)&&e[n]&&e[n][0](),e[n]=0},t=self.webpackChunk_jupyter_docprovider_extension=self.webpackChunk_jupyter_docprovider_extension||[];t.forEach(r.bind(null,0)),t.push=r.bind(null,t.push.bind(t))})(),x.nc=void
0;var E=x(496);(_JU
PYTERLAB=void
0===_JUPYTERLAB?{}:_JUPYTERLAB)["@jupyter/docprovider-extension"]=E})();
\ No newline at end of file
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn'
'--exclude=.svnignore'
old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/static/remoteEntry.2870ff42f76951af28a0.js
new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/static/remoteEntry.2870ff42f76951af28a0.js
---
old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/static/remoteEntry.2870ff42f76951af28a0.js
2020-02-02 01:00:00.000000000 +0100
+++
new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/static/remoteEntry.2870ff42f76951af28a0.js
1970-01-01 01:00:00.000000000 +0100
@@ -1 +0,0 @@
-var _JUPYTERLAB;(()=>{"use strict";var
e,r,t,o,a,n,i,l,u,s,d,f,p,c,v,h,b,y,m,g,j,w,P,S={496:(e,r,t)=>{var
o={"./index":()=>Promise.all([t.e(260),t.e(401),t.e(703)]).then((()=>()=>t(703))),"./extension":()=>Promise.all([t.e(260),t.e(401),t.e(703)]).then((()=>()=>t(703))),"./style":()=>t.e(944).then((()=>()=>t(944)))},a=(e,r)=>(t.R=r,r=t.o(o,e)?o[e]():Promise.resolve().then((()=>{throw
new Error('Module "'+e+'" does not exist in container.')})),t.R=void
0,r),n=(e,r)=>{if(t.S){var o="default",a=t.S[o];if(a&&a!==e)throw new
Error("Container initialization failed as it has already been initialized with
a different share scope");return
t.S[o]=e,t.I(o,r)}};t.d(r,{get:()=>a,init:()=>n})}},k={};function x(e){var
r=k[e];if(void 0!==r)return r.exports;var t=k[e]={id:e,exports:{}};return
S[e](t,t.exports,x),t.exports}x.m=S,x.c=k,x.n=e=>{var
r=e&&e.__esModule?()=>e.default:()=>e;return
x.d(r,{a:r}),r},x.d=(e,r)=>{for(var t in
r)x.o(r,t)&&!x.o(e,t)&&Object.defineProperty(e,t,{enumerable:!0,get:r[
t]})},x.f={},x.e=e=>Promise.all(Object.keys(x.f).reduce(((r,t)=>(x.f[t](e,r),r)),[])),x.u=e=>e+"."+{240:"dd1dbd559d6c95c85b3f",444:"12adfae9a2b50e91531f",576:"21a3c1a9ebaebb58d346",703:"17b6b904d18a75a9f3c6",944:"b85c55dff0f14165f872"}[e]+".js?v="+{240:"dd1dbd559d6c95c85b3f",444:"12adfae9a2b50e91531f",576:"21a3c1a9ebaebb58d346",703:"17b6b904d18a75a9f3c6",944:"b85c55dff0f14165f872"}[e],x.g=function(){if("object"==typeof
globalThis)return globalThis;try{return this||new Function("return
this")()}catch(e){if("object"==typeof window)return
window}}(),x.o=(e,r)=>Object.prototype.hasOwnProperty.call(e,r),e={},r="@jupyter/docprovider-extension:",x.l=(t,o,a,n)=>{if(e[t])e[t].push(o);else{var
i,l;if(void 0!==a)for(var
u=document.getElementsByTagName("script"),s=0;s<u.length;s++){var
d=u[s];if(d.getAttribute("src")==t||d.getAttribute("data-webpack")==r+a){i=d;break}}i||(l=!0,(i=document.createElement("script")).charset="utf-8",i.timeout=120,x.nc&&i.setAttribute("nonce",x.nc),i.setAttribute("d
ata-webpack",r+a),i.src=t),e[t]=[o];var
f=(r,o)=>{i.onerror=i.onload=null,clearTimeout(p);var a=e[t];if(delete
e[t],i.parentNode&&i.parentNode.removeChild(i),a&&a.forEach((e=>e(o))),r)return
r(o)},p=setTimeout(f.bind(null,void
0,{type:"timeout",target:i}),12e4);i.onerror=f.bind(null,i.onerror),i.onload=f.bind(null,i.onload),l&&document.head.appendChild(i)}},x.r=e=>{"undefined"!=typeof
Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},(()=>{x.S={};var
e={},r={};x.I=(t,o)=>{o||(o=[]);var
a=r[t];if(a||(a=r[t]={}),!(o.indexOf(a)>=0)){if(o.push(a),e[t])return
e[t];x.o(x.S,t)||(x.S[t]={});var
n=x.S[t],i="@jupyter/docprovider-extension",l=(e,r,t,o)=>{var
a=n[e]=n[e]||{},l=a[r];(!l||!l.loaded&&(!o!=!l.eager?o:i>l.from))&&(a[r]={get:t,from:i,eager:!!o})},u=[];return"default"===t&&(l("@jupyter/collaborative-drive","3.1.0",(()=>Promise.all([x.e(262),x.e(444)]).then((()=>()=>x(444))))),l("@jupyter/docprovid
er-extension","3.1.0",(()=>Promise.all([x.e(260),x.e(401),x.e(703)]).then((()=>()=>x(703))))),l("@jupyter/docprovider","3.1.0",(()=>Promise.all([x.e(260),x.e(262),x.e(240)]).then((()=>()=>x(240))))),l("y-websocket","1.5.4",(()=>Promise.all([x.e(576),x.e(206)]).then((()=>()=>x(576)))))),e[t]=u.length?Promise.all(u).then((()=>e[t]=1)):1}}})(),(()=>{var
e;x.g.importScripts&&(e=x.g.location+"");var
r=x.g.document;if(!e&&r&&(r.currentScript&&"SCRIPT"===r.currentScript.tagName.toUpperCase()&&(e=r.currentScript.src),!e)){var
t=r.getElementsByTagName("script");if(t.length)for(var
o=t.length-1;o>-1&&(!e||!/^http(s?):/.test(e));)e=t[o--].src}if(!e)throw new
Error("Automatic publicPath is not supported in this
browser");e=e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),x.p=e})(),t=e=>{var
r=e=>e.split(".").map((e=>+e==e?+e:e)),t=/^([^-+]+)?(?:-([^+]+))?(?:\+(.+))?$/.exec(e),o=t[1]?r(t[1]):[];return
t[2]&&(o.length++,o.push.apply(o,r(t[2]))),t[3]&&(o.push([]),o.push.apply(o,r(
t[3]))),o},o=(e,r)=>{e=t(e),r=t(r);for(var o=0;;){if(o>=e.length)return
o<r.length&&"u"!=(typeof r[o])[0];var a=e[o],n=(typeof
a)[0];if(o>=r.length)return"u"==n;var i=r[o],l=(typeof
i)[0];if(n!=l)return"o"==n&&"n"==l||"s"==l||"u"==n;if("o"!=n&&"u"!=n&&a!=i)return
a<i;o++}},a=e=>{var
r=e[0],t="";if(1===e.length)return"*";if(r+.5){t+=0==r?">=":-1==r?"<":1==r?"^":2==r?"~":r>0?"=":"!=";for(var
o=1,n=1;n<e.length;n++)o--,t+="u"==(typeof(l=e[n]))[0]?"-":(o>0?".":"")+(o=2,l);return
t}var i=[];for(n=1;n<e.length;n++){var
l=e[n];i.push(0===l?"not("+u()+")":1===l?"("+u()+" || "+u()+")":2===l?i.pop()+"
"+i.pop():a(l))}return u();function u(){return
i.pop().replace(/^\((.+)\)$/,"$1")}},n=(e,r)=>{if(0 in e){r=t(r);var
o=e[0],a=o<0;a&&(o=-o-1);for(var i=0,l=1,u=!0;;l++,i++){var
s,d,f=l<e.length?(typeof
e[l])[0]:"";if(i>=r.length||"o"==(d=(typeof(s=r[i]))[0]))return!u||("u"==f?l>o&&!a:""==f!=a);if("u"==d){if(!u||"u"!=f)return!1}else
if(u)if(f==d)if(l<=o){if(s!=e[l])return!1}else{if(a?s>e[l]:s<e[l]
)return!1;s!=e[l]&&(u=!1)}else
if("s"!=f&&"n"!=f){if(a||l<=o)return!1;u=!1,l--}else{if(l<=o||d<f!=a)return!1;u=!1}else"s"!=f&&"n"!=f&&(u=!1,l--)}}var
p=[],c=p.pop.bind(p);for(i=1;i<e.length;i++){var
v=e[i];p.push(1==v?c()|c():2==v?c()&c():v?n(v,r):!c())}return!!c()},i=(e,r)=>e&&x.o(e,r),l=e=>(e.loaded=1,e.get()),u=e=>Object.keys(e).reduce(((r,t)=>(e[t].eager&&(r[t]=e[t]),r)),{}),s=(e,r,t,a)=>{var
i=a?u(e[r]):e[r];return(r=Object.keys(i).reduce(((e,r)=>!n(t,r)||e&&!o(e,r)?e:r),0))&&i[r]},d=(e,r,t)=>{var
a=t?u(e[r]):e[r];return
Object.keys(a).reduce(((e,r)=>!e||!a[e].loaded&&o(e,r)?r:e),0)},f=(e,r,t,o)=>"Unsatisfied
version "+t+" from "+(t&&e[r][t].from)+" of shared singleton module "+r+"
(required "+a(o)+")",p=(e,r,t,o,n)=>{var i=e[t];return"No satisfying version
("+a(o)+")"+(n?" for eager consumption":"")+" of shared module "+t+" found in
shared scope "+r+".\nAvailable versions: "+Object.keys(i).map((e=>e+" from
"+i[e].from)).join(", ")},c=e=>{throw new Error(e)},v=e=>{"undefined"!=
typeof
console&&console.warn&&console.warn(e)},b=(e,r,t)=>t?t():((e,r)=>c("Shared
module "+r+" doesn't exist in shared scope
"+e))(e,r),y=(h=e=>function(r,t,o,a,n){var i=x.I(r);return
i&&i.then&&!o?i.then(e.bind(e,r,x.S[r],t,!1,a,n)):e(r,x.S[r],t,o,a,n)})(((e,r,t,o,a,n)=>{if(!i(r,t))return
b(e,t,n);var u=s(r,t,a,o);return u?l(u):n?n():void
c(p(r,e,t,a,o))})),m=h(((e,r,t,o,a,u)=>{if(!i(r,t))return b(e,t,u);var
s=d(r,t,o);return
n(a,s)||v(f(r,t,s,a)),l(r[t][s])})),g={},j={123:()=>m("default","@jupyterlab/apputils",!1,[1,4,4,3]),624:()=>m("default","@jupyterlab/translation",!1,[1,4,3,3]),672:()=>m("default","@jupyterlab/coreutils",!1,[1,6,3,3]),0:()=>m("default","@jupyter/ydoc",!1,[1,3,0,0,,"a3"]),132:()=>m("default","@jupyter/docprovider",!1,[1,3,1,0],(()=>Promise.all([x.e(262),x.e(240)]).then((()=>()=>x(240))))),180:()=>m("default","@jupyterlab/application",!1,[1,4,3,3]),227:()=>m("default","@jupyterlab/settingregistry",!1,[1,4,3,3]),236:()=>m("default","@jupyter/collaborative-drive"
,!1,[1,3,1,0],(()=>Promise.all([x.e(262),x.e(444)]).then((()=>()=>x(444))))),243:()=>m("default","@jupyterlab/fileeditor",!1,[1,4,3,3]),256:()=>m("default","@lumino/widgets",!1,[1,2,3,1,,"alpha",0]),295:()=>m("default","@jupyterlab/statusbar",!1,[1,4,3,3]),343:()=>m("default","@jupyterlab/logconsole",!1,[1,4,3,3]),920:()=>m("default","@jupyterlab/filebrowser",!1,[1,4,3,3]),977:()=>m("default","@jupyterlab/notebook",!1,[1,4,3,3]),262:()=>m("default","@lumino/coreutils",!1,[1,2,0,0]),345:()=>m("default","react",!1,[1,18,2,0]),560:()=>y("default","y-websocket",!1,[1,1,3,15],(()=>Promise.all([x.e(576),x.e(206)]).then((()=>()=>x(576))))),597:()=>m("default","@jupyterlab/ui-components",!1,[1,4,3,3]),602:()=>m("default","@lumino/signaling",!1,[1,2,0,0]),943:()=>m("default","@jupyterlab/services",!1,[1,7,3,3]),206:()=>m("default","yjs",!1,[1,13,5,40])},w={206:[206],240:[345,560,597,602,943],260:[123,624,672],262:[262],401:[0,132,180,227,236,243,256,295,343,920,977]},P={},x.f.consumes=(e,r)=
>{x.o(w,e)&&w[e].forEach((e=>{if(x.o(g,e))return r.push(g[e]);if(!P[e]){var
>t=r=>{g[e]=0,x.m[e]=t=>{delete x.c[e],t.exports=r()}};P[e]=!0;var
>o=r=>{delete g[e],x.m[e]=t=>{throw delete x.c[e],r}};try{var
>a=j[e]();a.then?r.push(g[e]=a.then(t).catch(o)):t(a)}catch(e){o(e)}}}))},(()=>{var
> e={552:0};x.f.j=(r,t)=>{var o=x.o(e,r)?e[r]:void
>0;if(0!==o)if(o)t.push(o[2]);else
>if(/^(2(06|60|62)|401)$/.test(r))e[r]=0;else{var a=new
>Promise(((t,a)=>o=e[r]=[t,a]));t.push(o[2]=a);var n=x.p+x.u(r),i=new
>Error;x.l(n,(t=>{if(x.o(e,r)&&(0!==(o=e[r])&&(e[r]=void 0),o)){var
>a=t&&("load"===t.type?"missing":t.type),n=t&&t.target&&t.target.src;i.message="Loading
> chunk "+r+" failed.\n("+a+":
>"+n+")",i.name="ChunkLoadError",i.type=a,i.request=n,o[1](i)}}),"chunk-"+r,r)}};var
> r=(r,t)=>{var o,a,[n,i,l]=t,u=0;if(n.some((r=>0!==e[r]))){for(o in
>i)x.o(i,o)&&(x.m[o]=i[o]);l&&l(x)}for(r&&r(t);u<n.length;u++)a=n[u],x.o(e,a)&&e[a]&&e[a][0](),e[a]=0},t=self.webpackChunk_jupyter_docprovider_extension=self.webpackChunk_
jupyter_docprovider_extension||[];t.forEach(r.bind(null,0)),t.push=r.bind(null,t.push.bind(t))})(),x.nc=void
0;var E=x(496);(_JUPYTERLAB=void
0===_JUPYTERLAB?{}:_JUPYTERLAB)["@jupyter/docprovider-extension"]=E})();
\ No newline at end of file
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn'
'--exclude=.svnignore'
old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/static/third-party-licenses.json
new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/static/third-party-licenses.json
---
old/jupyter_docprovider-1.1.0/jupyter_docprovider/labextension/static/third-party-licenses.json
2020-02-02 01:00:00.000000000 +0100
+++
new/jupyter_docprovider-2.0.2/jupyter_docprovider/labextension/static/third-party-licenses.json
2020-02-02 01:00:00.000000000 +0100
@@ -2,19 +2,19 @@
"packages": [
{
"name": "@jupyter/collaboration",
- "versionInfo": "3.1.0",
+ "versionInfo": "4.0.2",
"licenseId": "BSD-3-Clause",
"extractedText": ""
},
{
"name": "@jupyter/collaborative-drive",
- "versionInfo": "3.1.0",
+ "versionInfo": "4.0.2",
"licenseId": "BSD-3-Clause",
"extractedText": ""
},
{
"name": "@jupyter/docprovider",
- "versionInfo": "3.1.0",
+ "versionInfo": "4.0.2",
"licenseId": "BSD-3-Clause",
"extractedText": ""
},
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn'
'--exclude=.svnignore'
old/jupyter_docprovider-1.1.0/packages/docprovider/package.json
new/jupyter_docprovider-2.0.2/packages/docprovider/package.json
--- old/jupyter_docprovider-1.1.0/packages/docprovider/package.json
2020-02-02 01:00:00.000000000 +0100
+++ new/jupyter_docprovider-2.0.2/packages/docprovider/package.json
2020-02-02 01:00:00.000000000 +0100
@@ -1,6 +1,6 @@
{
"name": "@jupyter/docprovider",
- "version": "3.1.0",
+ "version": "4.0.2",
"description": "JupyterLab - Document Provider",
"homepage": "https://github.com/jupyterlab/jupyter-collaboration",
"bugs": {
@@ -41,28 +41,28 @@
"watch": "tsc -b --watch"
},
"dependencies": {
- "@jupyter/collaborative-drive": "^3.1.0",
- "@jupyter/ydoc": "^2.0.0 || ^3.0.0",
- "@jupyterlab/apputils": "^4.2.0",
- "@jupyterlab/cells": "^4.2.0",
- "@jupyterlab/coreutils": "^6.2.0",
- "@jupyterlab/notebook": "^4.2.0",
- "@jupyterlab/services": "^7.2.0",
- "@jupyterlab/translation": "^4.2.0",
- "@lumino/coreutils": "^2.1.0",
- "@lumino/disposable": "^2.1.0",
- "@lumino/signaling": "^2.1.0",
- "@lumino/widgets": "^2.2.0",
+ "@jupyter/collaborative-drive": "^4.0.2",
+ "@jupyter/ydoc": "^2.1.3 || ^3.0.0",
+ "@jupyterlab/apputils": "^4.4.0",
+ "@jupyterlab/cells": "^4.4.0",
+ "@jupyterlab/coreutils": "^6.4.0",
+ "@jupyterlab/notebook": "^4.4.0",
+ "@jupyterlab/services": "^7.4.0",
+ "@jupyterlab/translation": "^4.4.0",
+ "@lumino/coreutils": "^2.2.1",
+ "@lumino/disposable": "^2.1.4",
+ "@lumino/signaling": "^2.1.4",
+ "@lumino/widgets": "^2.7.0",
"y-protocols": "^1.0.5",
"y-websocket": "^1.3.15",
"yjs": "^13.5.40"
},
"devDependencies": {
- "@jupyterlab/testing": "^4.0.0",
+ "@jupyterlab/testing": "^4.4.0",
"@types/jest": "^29.2.0",
"jest": "^29.5.0",
"rimraf": "^4.1.2",
- "typescript": "~5.0.4"
+ "typescript": "~5.1.6"
},
"publishConfig": {
"access": "public"
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn'
'--exclude=.svnignore'
old/jupyter_docprovider-1.1.0/packages/docprovider/src/__tests__/forkManager.spec.ts
new/jupyter_docprovider-2.0.2/packages/docprovider/src/__tests__/forkManager.spec.ts
---
old/jupyter_docprovider-1.1.0/packages/docprovider/src/__tests__/forkManager.spec.ts
2020-02-02 01:00:00.000000000 +0100
+++
new/jupyter_docprovider-2.0.2/packages/docprovider/src/__tests__/forkManager.spec.ts
2020-02-02 01:00:00.000000000 +0100
@@ -1,7 +1,7 @@
// Copyright (c) Jupyter Development Team.
// Distributed under the terms of the Modified BSD License.
-import { ICollaborativeDrive } from '@jupyter/collaborative-drive';
+import { ICollaborativeContentProvider } from '@jupyter/collaborative-drive';
import {
ForkManager,
JUPYTER_COLLABORATION_FORK_EVENTS_URI
@@ -11,10 +11,9 @@
import { requestAPI } from '../requests';
jest.mock('../requests');
-const driveMock = {
- name: 'rtc',
+const contentProviderMock = {
providers: new Map()
-} as ICollaborativeDrive;
+} as ICollaborativeContentProvider;
const stream = new Signal({});
const eventManagerMock = {
stream: stream as any
@@ -24,7 +23,7 @@
let manager: ForkManager;
beforeEach(() => {
manager = new ForkManager({
- drive: driveMock,
+ contentProvider: contentProviderMock,
eventManager: eventManagerMock
});
});
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn'
'--exclude=.svnignore'
old/jupyter_docprovider-1.1.0/packages/docprovider/src/forkManager.ts
new/jupyter_docprovider-2.0.2/packages/docprovider/src/forkManager.ts
--- old/jupyter_docprovider-1.1.0/packages/docprovider/src/forkManager.ts
2020-02-02 01:00:00.000000000 +0100
+++ new/jupyter_docprovider-2.0.2/packages/docprovider/src/forkManager.ts
2020-02-02 01:00:00.000000000 +0100
@@ -3,7 +3,7 @@
* Distributed under the terms of the Modified BSD License.
*/
-import { ICollaborativeDrive } from '@jupyter/collaborative-drive';
+import { ICollaborativeContentProvider } from '@jupyter/collaborative-drive';
import { URLExt } from '@jupyterlab/coreutils';
import { Event } from '@jupyterlab/services';
import { ISignal, Signal } from '@lumino/signaling';
@@ -22,8 +22,8 @@
export class ForkManager implements IForkManager {
constructor(options: ForkManager.IOptions) {
- const { drive, eventManager } = options;
- this._drive = drive;
+ const { contentProvider, eventManager } = options;
+ this._contentProvider = contentProvider;
this._eventManager = eventManager;
this._eventManager.stream.connect(this._handleEvent, this);
}
@@ -81,14 +81,12 @@
type: string;
}): IForkProvider | undefined {
const { documentPath, format, type } = options;
- const drive = this._drive;
- if (drive) {
- const driveName = drive.name;
- let docPath = documentPath;
- if (documentPath.startsWith(driveName)) {
- docPath = documentPath.slice(driveName.length + 1);
- }
- const provider = drive.providers.get(`${format}:${type}:${docPath}`);
+ const contentProvider = this._contentProvider;
+ if (contentProvider) {
+ const docPath = documentPath;
+ const provider = contentProvider.providers.get(
+ `${format}:${type}:${docPath}`
+ );
return provider as IForkProvider | undefined;
}
return;
@@ -112,7 +110,7 @@
}
private _disposed = false;
- private _drive: ICollaborativeDrive | undefined;
+ private _contentProvider: ICollaborativeContentProvider | undefined;
private _eventManager: Event.IManager | undefined;
private _forkAddedSignal = new Signal<ForkManager, IForkChangedEvent>(this);
private _forkDeletedSignal = new Signal<ForkManager,
IForkChangedEvent>(this);
@@ -120,7 +118,7 @@
export namespace ForkManager {
export interface IOptions {
- drive: ICollaborativeDrive;
+ contentProvider: ICollaborativeContentProvider;
eventManager: Event.IManager;
}
}
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn'
'--exclude=.svnignore'
old/jupyter_docprovider-1.1.0/packages/docprovider/src/ydrive.ts
new/jupyter_docprovider-2.0.2/packages/docprovider/src/ydrive.ts
--- old/jupyter_docprovider-1.1.0/packages/docprovider/src/ydrive.ts
2020-02-02 01:00:00.000000000 +0100
+++ new/jupyter_docprovider-2.0.2/packages/docprovider/src/ydrive.ts
2020-02-02 01:00:00.000000000 +0100
@@ -3,16 +3,22 @@
import { PageConfig, URLExt } from '@jupyterlab/coreutils';
import { TranslationBundle } from '@jupyterlab/translation';
-import { Contents, Drive, User } from '@jupyterlab/services';
+import {
+ Contents,
+ IContentProvider,
+ RestContentProvider,
+ SharedDocumentFactory,
+ ServerConnection,
+ User
+} from '@jupyterlab/services';
import { ISignal, Signal } from '@lumino/signaling';
import { DocumentChange, ISharedDocument, YDocument } from '@jupyter/ydoc';
import { WebSocketProvider } from './yprovider';
import {
- ICollaborativeDrive,
- ISharedModelFactory,
- SharedDocumentFactory
+ IDocumentProvider,
+ ISharedModelFactory
} from '@jupyter/collaborative-drive';
import { Awareness } from 'y-protocols/awareness';
@@ -31,56 +37,38 @@
format: string;
}
-/**
- * A Collaborative implementation for an `IDrive`, talking to the
- * server using the Jupyter REST API and a WebSocket connection.
- */
-export class YDrive extends Drive implements ICollaborativeDrive {
- /**
- * Construct a new drive object.
- *
- * @param user - The user manager to add the identity to the awareness of
documents.
- */
- constructor(
- user: User.IManager,
- translator: TranslationBundle,
- globalAwareness: Awareness | null
- ) {
- super({ name: 'RTC' });
- this._user = user;
- this._trans = translator;
- this._globalAwareness = globalAwareness;
- this._providers = new Map<string, WebSocketProvider>();
+namespace RtcContentProvider {
+ export interface IOptions extends RestContentProvider.IOptions {
+ user: User.IManager;
+ trans: TranslationBundle;
+ globalAwareness: Awareness | null;
+ }
+}
+export class RtcContentProvider
+ extends RestContentProvider
+ implements IContentProvider
+{
+ constructor(options: RtcContentProvider.IOptions) {
+ super(options);
+ this._user = options.user;
+ this._trans = options.trans;
+ this._globalAwareness = options.globalAwareness;
+ this._serverSettings = options.serverSettings;
this.sharedModelFactory = new SharedModelFactory(this._onCreate);
- super.fileChanged.connect((_, change) => {
- // pass through any events from the Drive superclass
- this._ydriveFileChanged.emit(change);
- });
+ this._providers = new Map<string, WebSocketProvider>();
}
/**
- * SharedModel factory for the YDrive.
+ * SharedModel factory for the content provider.
*/
readonly sharedModelFactory: ISharedModelFactory;
- get providers(): Map<string, WebSocketProvider> {
+ get providers(): Map<string, IDocumentProvider> {
return this._providers;
}
/**
- * Dispose of the resources held by the manager.
- */
- dispose(): void {
- if (this.isDisposed) {
- return;
- }
- this._providers.forEach(p => p.dispose());
- this._providers.clear();
- super.dispose();
- }
-
- /**
* Get a file or directory.
*
* @param localPath: The path to the file.
@@ -88,8 +76,6 @@
* @param options: The options used to fetch the file.
*
* @returns A promise which resolves with the file content.
- *
- * Uses the [Jupyter Notebook
API](http://petstore.swagger.io/?url=https://raw.githubusercontent.com/jupyter/notebook/master/notebook/services/api/api.yaml#!/contents)
and validates the response model.
*/
async get(
localPath: string,
@@ -166,7 +152,7 @@
}
try {
const provider = new WebSocketProvider({
- url: URLExt.join(this.serverSettings.wsUrl, DOCUMENT_PROVIDER_URL),
+ url: URLExt.join(this._serverSettings.wsUrl, DOCUMENT_PROVIDER_URL),
path: options.path,
format: options.format,
contentType: options.contentType,
@@ -177,9 +163,9 @@
// Add the document path in the list of opened ones for this user.
const state = this._globalAwareness?.getLocalState() || {};
- const documents: any[] = state.documents || [];
+ const documents: string[] = state.documents || [];
if (!documents.includes(options.path)) {
- documents.push(`${this.name}:${options.path}`);
+ documents.push(options.path);
this._globalAwareness?.setLocalStateField('documents', documents);
}
@@ -228,7 +214,7 @@
// Remove the document path from the list of opened ones for this user.
const state = this._globalAwareness?.getLocalState() || {};
const documents: any[] = state.documents || [];
- const index = documents.indexOf(`${this.name}:${options.path}`);
+ const index = documents.indexOf(options.path);
if (index > -1) {
documents.splice(index, 1);
}
@@ -245,9 +231,10 @@
private _user: User.IManager;
private _trans: TranslationBundle;
- private _providers: Map<string, WebSocketProvider>;
private _globalAwareness: Awareness | null;
+ private _providers: Map<string, WebSocketProvider>;
private _ydriveFileChanged = new Signal<this, Contents.IChangedArgs>(this);
+ private _serverSettings: ServerConnection.ISettings;
}
/**
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn'
'--exclude=.svnignore'
old/jupyter_docprovider-1.1.0/packages/docprovider-extension/package.json
new/jupyter_docprovider-2.0.2/packages/docprovider-extension/package.json
--- old/jupyter_docprovider-1.1.0/packages/docprovider-extension/package.json
2020-02-02 01:00:00.000000000 +0100
+++ new/jupyter_docprovider-2.0.2/packages/docprovider-extension/package.json
2020-02-02 01:00:00.000000000 +0100
@@ -1,6 +1,6 @@
{
"name": "@jupyter/docprovider-extension",
- "version": "3.1.0",
+ "version": "4.0.2",
"description": "JupyterLab - Collaborative Shared Models",
"keywords": [
"jupyter",
@@ -53,29 +53,29 @@
"watch:labextension": "jupyter labextension watch ."
},
"dependencies": {
- "@jupyter/collaborative-drive": "^3.1.0",
- "@jupyter/docprovider": "^3.1.0",
- "@jupyter/ydoc": "^2.0.0 || ^3.0.0",
- "@jupyterlab/application": "^4.2.0",
- "@jupyterlab/apputils": "^4.2.0",
- "@jupyterlab/docregistry": "^4.2.0",
- "@jupyterlab/filebrowser": "^4.2.0",
- "@jupyterlab/fileeditor": "^4.2.0",
- "@jupyterlab/logconsole": "^4.2.0",
- "@jupyterlab/notebook": "^4.2.0",
- "@jupyterlab/settingregistry": "^4.2.0",
- "@jupyterlab/translation": "^4.2.0",
- "@lumino/commands": "^2.1.0",
+ "@jupyter/collaborative-drive": "^4.0.2",
+ "@jupyter/docprovider": "^4.0.2",
+ "@jupyter/ydoc": "^2.1.3 || ^3.0.0",
+ "@jupyterlab/application": "^4.4.0",
+ "@jupyterlab/apputils": "^4.4.0",
+ "@jupyterlab/docregistry": "^4.4.0",
+ "@jupyterlab/filebrowser": "^4.4.0",
+ "@jupyterlab/fileeditor": "^4.4.0",
+ "@jupyterlab/logconsole": "^4.4.0",
+ "@jupyterlab/notebook": "^4.4.0",
+ "@jupyterlab/settingregistry": "^4.4.0",
+ "@jupyterlab/translation": "^4.4.0",
+ "@lumino/commands": "^2.3.2",
"y-protocols": "^1.0.5",
"y-websocket": "^1.3.15",
"yjs": "^13.5.40"
},
"devDependencies": {
- "@jupyterlab/builder": "^4.0.0",
+ "@jupyterlab/builder": "^4.4.0",
"@types/react": "~18.3.1",
"npm-run-all": "^4.1.5",
"rimraf": "^4.1.2",
- "typescript": "~5.0.4"
+ "typescript": "~5.1.6"
},
"publishConfig": {
"access": "public"
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn'
'--exclude=.svnignore'
old/jupyter_docprovider-1.1.0/packages/docprovider-extension/src/filebrowser.ts
new/jupyter_docprovider-2.0.2/packages/docprovider-extension/src/filebrowser.ts
---
old/jupyter_docprovider-1.1.0/packages/docprovider-extension/src/filebrowser.ts
2020-02-02 01:00:00.000000000 +0100
+++
new/jupyter_docprovider-2.0.2/packages/docprovider-extension/src/filebrowser.ts
2020-02-02 01:00:00.000000000 +0100
@@ -4,45 +4,44 @@
*/
import {
- ILabShell,
- IRouter,
JupyterFrontEnd,
JupyterFrontEndPlugin
} from '@jupyterlab/application';
import { Dialog, showDialog } from '@jupyterlab/apputils';
import { DocumentWidget, IDocumentWidget } from '@jupyterlab/docregistry';
import { Widget } from '@lumino/widgets';
-import {
- FileBrowser,
- IDefaultFileBrowser,
- IFileBrowserFactory
-} from '@jupyterlab/filebrowser';
+
import { IStatusBar } from '@jupyterlab/statusbar';
+import { ContentsManager } from '@jupyterlab/services';
-import { IEditorTracker } from '@jupyterlab/fileeditor';
+import {
+ IEditorTracker,
+ IEditorWidgetFactory,
+ FileEditorFactory
+} from '@jupyterlab/fileeditor';
import { ILogger, ILoggerRegistry } from '@jupyterlab/logconsole';
-import { INotebookTracker } from '@jupyterlab/notebook';
+import {
+ INotebookTracker,
+ INotebookWidgetFactory,
+ NotebookWidgetFactory
+} from '@jupyterlab/notebook';
import { ISettingRegistry } from '@jupyterlab/settingregistry';
import { ITranslator, nullTranslator } from '@jupyterlab/translation';
-import { CommandRegistry } from '@lumino/commands';
-
import { YFile, YNotebook } from '@jupyter/ydoc';
import {
- ICollaborativeDrive,
+ ICollaborativeContentProvider,
IGlobalAwareness
} from '@jupyter/collaborative-drive';
-import { IForkProvider, TimelineWidget, YDrive } from '@jupyter/docprovider';
+import {
+ IForkProvider,
+ TimelineWidget,
+ RtcContentProvider
+} from '@jupyter/docprovider';
import { Awareness } from 'y-protocols/awareness';
import { URLExt } from '@jupyterlab/coreutils';
-/**
- * The command IDs used by the file browser plugin.
- */
-namespace CommandIDs {
- export const openPath = 'filebrowser:open-path';
-}
const DOCUMENT_TIMELINE_URL = 'api/collaboration/timeline';
const TWO_SESSIONS_WARNING =
@@ -50,26 +49,43 @@
'This is not supported. Please close this view; otherwise, ' +
'some of your edits may not be saved properly.';
-/**
- * The default collaborative drive provider.
- */
-export const drive: JupyterFrontEndPlugin<ICollaborativeDrive> = {
- id: '@jupyter/docprovider-extension:drive',
- description: 'The default collaborative drive provider',
- provides: ICollaborativeDrive,
- requires: [ITranslator],
- optional: [IGlobalAwareness],
- activate: (
- app: JupyterFrontEnd,
- translator: ITranslator,
- globalAwareness: Awareness | null
- ): ICollaborativeDrive => {
- const trans = translator.load('jupyter_collaboration');
- const drive = new YDrive(app.serviceManager.user, trans, globalAwareness);
- app.serviceManager.contents.addDrive(drive);
- return drive;
- }
-};
+export const rtcContentProvider:
JupyterFrontEndPlugin<ICollaborativeContentProvider> =
+ {
+ id: '@jupyter/docprovider-extension:content-provider',
+ description: 'The RTC content provider',
+ provides: ICollaborativeContentProvider,
+ requires: [ITranslator],
+ optional: [IGlobalAwareness],
+ activate: (
+ app: JupyterFrontEnd,
+ translator: ITranslator,
+ globalAwareness: Awareness | null
+ ): ICollaborativeContentProvider => {
+ const trans = translator.load('jupyter_collaboration');
+ const defaultDrive = (app.serviceManager.contents as ContentsManager)
+ .defaultDrive;
+ if (!defaultDrive) {
+ throw Error(
+ 'Cannot initialize content provider: default drive property not
accessible on contents manager instance.'
+ );
+ }
+ const registry = defaultDrive.contentProviderRegistry;
+ if (!registry) {
+ throw Error(
+ 'Cannot initialize content provider: no content provider registry.'
+ );
+ }
+ const rtcContentProvider = new RtcContentProvider({
+ apiEndpoint: '/api/contents',
+ serverSettings: defaultDrive.serverSettings,
+ user: app.serviceManager.user,
+ trans,
+ globalAwareness
+ });
+ registry.register('rtc', rtcContentProvider);
+ return rtcContentProvider;
+ }
+ };
/**
* Plugin to register the shared model factory for the content type 'file'.
@@ -79,13 +95,20 @@
description:
"Plugin to register the shared model factory for the content type 'file'",
autoStart: true,
- requires: [ICollaborativeDrive],
- optional: [],
- activate: (app: JupyterFrontEnd, drive: ICollaborativeDrive): void => {
+ requires: [ICollaborativeContentProvider, IEditorWidgetFactory],
+ activate: (
+ app: JupyterFrontEnd,
+ contentProvider: ICollaborativeContentProvider,
+ editorFactory: FileEditorFactory.IFactory
+ ): void => {
const yFileFactory = () => {
return new YFile();
};
- drive.sharedModelFactory.registerDocumentFactory('file', yFileFactory);
+ contentProvider.sharedModelFactory.registerDocumentFactory(
+ 'file',
+ yFileFactory
+ );
+ editorFactory.contentProviderId = 'rtc';
}
};
@@ -97,11 +120,12 @@
description:
"Plugin to register the shared model factory for the content type
'notebook'",
autoStart: true,
- requires: [ICollaborativeDrive],
+ requires: [ICollaborativeContentProvider, INotebookWidgetFactory],
optional: [ISettingRegistry],
activate: (
app: JupyterFrontEnd,
- drive: YDrive,
+ contentProvider: ICollaborativeContentProvider,
+ notebookFactory: NotebookWidgetFactory.IFactory,
settingRegistry: ISettingRegistry | null
): void => {
let disableDocumentWideUndoRedo = true;
@@ -131,10 +155,11 @@
disableDocumentWideUndoRedo
});
};
- drive.sharedModelFactory.registerDocumentFactory(
+ contentProvider.sharedModelFactory.registerDocumentFactory(
'notebook',
yNotebookFactory
);
+ notebookFactory.contentProviderId = 'rtc';
}
};
/**
@@ -144,11 +169,11 @@
id: '@jupyter/docprovider-extension:statusBarTimeline',
description: 'Plugin to add a timeline slider to the status bar',
autoStart: true,
- requires: [IStatusBar, ICollaborativeDrive],
+ requires: [IStatusBar, ICollaborativeContentProvider],
activate: async (
app: JupyterFrontEnd,
statusBar: IStatusBar,
- drive: ICollaborativeDrive
+ contentProvider: ICollaborativeContentProvider
): Promise<void> => {
try {
let sliderItem: Widget | null = null;
@@ -158,39 +183,43 @@
documentPath: string,
documentId: string
) => {
- if (documentId && documentPath.split(':')[0] === 'RTC') {
- if (drive) {
- // Remove 'RTC:' from document path
- documentPath = documentPath.slice(drive.name.length + 1);
- // Dispose of the previous timelineWidget if it exists
- if (timelineWidget) {
- timelineWidget.dispose();
- timelineWidget = null;
- }
+ if (!documentId) {
+ return;
+ }
+ // Dispose of the previous timelineWidget if it exists
+ if (timelineWidget) {
+ timelineWidget.dispose();
+ timelineWidget = null;
+ }
- const [format, type] = documentId.split(':');
- const provider = drive.providers.get(
- `${format}:${type}:${documentPath}`
- ) as unknown as IForkProvider;
- const fullPath = URLExt.join(
- app.serviceManager.serverSettings.baseUrl,
- DOCUMENT_TIMELINE_URL,
- documentPath
- );
+ const [format, type] = documentId.split(':');
+ const provider = contentProvider.providers.get(
+ `${format}:${type}:${documentPath}`
+ );
+ if (!provider) {
+ // this can happen for documents which are not provisioned with RTC
+ return;
+ }
- timelineWidget = new TimelineWidget(
- fullPath,
- provider,
- provider.contentType,
- provider.format,
- DOCUMENT_TIMELINE_URL
- );
+ const forkProvider = provider as unknown as IForkProvider;
- const elt = document.getElementById('jp-slider-status-bar');
- if (elt && !timelineWidget.isAttached) {
- Widget.attach(timelineWidget, elt);
- }
- }
+ const fullPath = URLExt.join(
+ app.serviceManager.serverSettings.baseUrl,
+ DOCUMENT_TIMELINE_URL,
+ documentPath
+ );
+
+ timelineWidget = new TimelineWidget(
+ fullPath,
+ forkProvider,
+ forkProvider.contentType,
+ forkProvider.format,
+ DOCUMENT_TIMELINE_URL
+ );
+
+ const elt = document.getElementById('jp-slider-status-bar');
+ if (elt && !timelineWidget.isAttached) {
+ Widget.attach(timelineWidget, elt);
}
};
@@ -228,19 +257,7 @@
const currentWidget = app.shell
.currentWidget as DocumentWidget | null;
- if (
- currentWidget &&
- currentWidget.context &&
- typeof currentWidget.context.path === 'string'
- ) {
- const documentPath = currentWidget.context.path;
- const documentId =
- currentWidget.context.model.sharedModel.getState(
- 'document_id'
- ) as string;
- return !!documentId && documentPath.split(':')[0] === 'RTC';
- }
- return false;
+ return currentWidget?.context?.model?.collaborative || false;
}
});
}
@@ -252,52 +269,6 @@
};
/**
- * The default file browser factory provider.
- */
-export const defaultFileBrowser: JupyterFrontEndPlugin<IDefaultFileBrowser> = {
- id: '@jupyter/docprovider-extension:defaultFileBrowser',
- description: 'The default file browser factory provider',
- provides: IDefaultFileBrowser,
- requires: [ICollaborativeDrive, IFileBrowserFactory],
- optional: [IRouter, JupyterFrontEnd.ITreeResolver, ILabShell, ITranslator],
- activate: async (
- app: JupyterFrontEnd,
- drive: YDrive,
- fileBrowserFactory: IFileBrowserFactory,
- router: IRouter | null,
- tree: JupyterFrontEnd.ITreeResolver | null,
- labShell: ILabShell | null,
- translator: ITranslator | null
- ): Promise<IDefaultFileBrowser> => {
- const { commands } = app;
- const trans = (translator ?? nullTranslator).load('jupyterlab');
- app.serviceManager.contents.addDrive(drive);
-
- // Manually restore and load the default file browser.
- const defaultBrowser = fileBrowserFactory.createFileBrowser('filebrowser',
{
- auto: false,
- restore: false,
- driveName: drive.name
- });
- defaultBrowser.node.setAttribute('role', 'region');
- defaultBrowser.node.setAttribute(
- 'aria-label',
- trans.__('File Browser Section')
- );
-
- void Private.restoreBrowser(
- defaultBrowser,
- commands,
- router,
- tree,
- labShell
- );
-
- return defaultBrowser;
- }
-};
-
-/**
* The default collaborative drive provider.
*/
export const logger: JupyterFrontEndPlugin<void> = {
@@ -383,59 +354,3 @@
})();
}
};
-
-namespace Private {
- /**
- * Restores file browser state and overrides state if tree resolver resolves.
- */
- export async function restoreBrowser(
- browser: FileBrowser,
- commands: CommandRegistry,
- router: IRouter | null,
- tree: JupyterFrontEnd.ITreeResolver | null,
- labShell: ILabShell | null
- ): Promise<void> {
- const restoring = 'jp-mod-restoring';
-
- browser.addClass(restoring);
-
- if (!router) {
- await browser.model.restore(browser.id);
- await browser.model.refresh();
- browser.removeClass(restoring);
- return;
- }
-
- const listener = async () => {
- router.routed.disconnect(listener);
-
- const paths = await tree?.paths;
-
- if (paths?.file || paths?.browser) {
- // Restore the model without populating it.
- await browser.model.restore(browser.id, false);
- if (paths.file) {
- await commands.execute(CommandIDs.openPath, {
- path: paths.file,
- dontShowBrowser: true
- });
- }
- if (paths.browser) {
- await commands.execute(CommandIDs.openPath, {
- path: paths.browser,
- dontShowBrowser: true
- });
- }
- } else {
- await browser.model.restore(browser.id);
- await browser.model.refresh();
- }
- browser.removeClass(restoring);
-
- if (labShell?.isEmpty('main')) {
- void commands.execute('launcher:create');
- }
- };
- router.routed.connect(listener);
- }
-}
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn'
'--exclude=.svnignore'
old/jupyter_docprovider-1.1.0/packages/docprovider-extension/src/forkManager.ts
new/jupyter_docprovider-2.0.2/packages/docprovider-extension/src/forkManager.ts
---
old/jupyter_docprovider-1.1.0/packages/docprovider-extension/src/forkManager.ts
2020-02-02 01:00:00.000000000 +0100
+++
new/jupyter_docprovider-2.0.2/packages/docprovider-extension/src/forkManager.ts
2020-02-02 01:00:00.000000000 +0100
@@ -3,7 +3,7 @@
* Distributed under the terms of the Modified BSD License.
*/
-import { ICollaborativeDrive } from '@jupyter/collaborative-drive';
+import { ICollaborativeContentProvider } from '@jupyter/collaborative-drive';
import {
ForkManager,
IForkManager,
@@ -18,11 +18,14 @@
export const forkManagerPlugin: JupyterFrontEndPlugin<IForkManager> = {
id: '@jupyter/docprovider-extension:forkManager',
autoStart: true,
- requires: [ICollaborativeDrive],
+ requires: [ICollaborativeContentProvider],
provides: IForkManagerToken,
- activate: (app: JupyterFrontEnd, drive: ICollaborativeDrive) => {
+ activate: (
+ app: JupyterFrontEnd,
+ contentProvider: ICollaborativeContentProvider
+ ) => {
const eventManager = app.serviceManager.events;
- const manager = new ForkManager({ drive, eventManager });
+ const manager = new ForkManager({ contentProvider, eventManager });
return manager;
}
};
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn'
'--exclude=.svnignore'
old/jupyter_docprovider-1.1.0/packages/docprovider-extension/src/index.ts
new/jupyter_docprovider-2.0.2/packages/docprovider-extension/src/index.ts
--- old/jupyter_docprovider-1.1.0/packages/docprovider-extension/src/index.ts
2020-02-02 01:00:00.000000000 +0100
+++ new/jupyter_docprovider-2.0.2/packages/docprovider-extension/src/index.ts
2020-02-02 01:00:00.000000000 +0100
@@ -8,10 +8,9 @@
import { JupyterFrontEndPlugin } from '@jupyterlab/application';
import {
- drive,
+ rtcContentProvider,
yfile,
ynotebook,
- defaultFileBrowser,
logger,
statusBarTimeline
} from './filebrowser';
@@ -21,11 +20,10 @@
/**
* Export the plugins as default.
*/
-const plugins: JupyterFrontEndPlugin<any>[] = [
- drive,
+const plugins: JupyterFrontEndPlugin<unknown>[] = [
+ rtcContentProvider,
yfile,
ynotebook,
- defaultFileBrowser,
logger,
notebookCellExecutor,
statusBarTimeline,