Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
erp5
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Boris Kocherov
erp5
Commits
f9435ae1
Commit
f9435ae1
authored
Dec 01, 2016
by
Boris Kocherov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
erp5_officejs: using MappingStorge thx
@vincentB
parent
c7647853
Changes
6
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
181 additions
and
302 deletions
+181
-302
bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_onlyoffice_landing_js.js
.../web_page_module/gadget_officejs_onlyoffice_landing_js.js
+18
-25
bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_onlyoffice_landing_js.xml
...web_page_module/gadget_officejs_onlyoffice_landing_js.xml
+2
-2
bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_router_js.js
...TemplateItem/web_page_module/gadget_officejs_router_js.js
+21
-28
bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_router_js.xml
...emplateItem/web_page_module/gadget_officejs_router_js.xml
+2
-2
bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_serviceworker_js.js
...eItem/web_page_module/gadget_officejs_serviceworker_js.js
+136
-243
bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_serviceworker_js.xml
...Item/web_page_module/gadget_officejs_serviceworker_js.xml
+2
-2
No files found.
bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_onlyoffice_landing_js.js
View file @
f9435ae1
...
...
@@ -19,13 +19,10 @@
function
get_jio_cache_storage
(
name
)
{
return
{
type
:
"
query
"
,
sub_storage
:
{
type
:
"
uuid
"
,
sub_storage
:
{
type
:
"
indexeddb
"
,
database
:
'
officejs_
'
+
name
+
'
_cache_erp5
'
}
}
};
}
...
...
@@ -146,7 +143,7 @@
return
jIO
.
createJIO
({
type
:
"
replicate
"
,
query
:
{
query
:
'
(portal_type: ("Web Style", "Web Page", "Web Script")) AND
'
+
query
:
'
reference: "%" AND
(portal_type: ("Web Style", "Web Page", "Web Script")) AND
'
+
erp5_query
+
modification_date
,
limit
:
[
0
,
1234567890
]
},
...
...
@@ -158,26 +155,22 @@
check_remote_modification
:
true
,
check_remote_creation
:
true
,
check_remote_deletion
:
true
,
local_sub_storage
:
{
type
:
"
attachasproperty
"
,
map
:
{
text_content
:
{
body_name
:
"
text_content
"
,
content_type_name
:
"
content_type
"
},
data
:
{
body_name
:
"
data
"
,
content_type_name
:
"
content_type
"
}
},
sub_storage
:
get_jio_cache_storage
(
name
)
},
//use_bulk_get: true,
use_bulk
:
false
,
local_sub_storage
:
get_jio_cache_storage
(
name
),
remote_sub_storage
:
{
type
:
"
mapping
"
,
sub_storage
:
{
type
:
"
erp5
"
,
url
:
(
new
URI
(
"
hateoasnoauth
"
))
.
absoluteTo
(
location
.
href
)
.
toString
(),
default_view_reference
:
"
jio_view
"
},
mapping_dict
:
{
"
id
"
:
{
"
equal
"
:
"
url_string
"
,
"
default_property
"
:
"
reference
"
}}
}
});
}
...
...
bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_onlyoffice_landing_js.xml
View file @
f9435ae1
...
...
@@ -238,7 +238,7 @@
</item>
<item>
<key>
<string>
serial
</string>
</key>
<value>
<string>
955.
8487.48731.31863
</string>
</value>
<value>
<string>
955.
20973.48171.43827
</string>
</value>
</item>
<item>
<key>
<string>
state
</string>
</key>
...
...
@@ -256,7 +256,7 @@
</tuple>
<state>
<tuple>
<float>
14
78563709.48
</float>
<float>
14
80578496.19
</float>
<string>
UTC
</string>
</tuple>
</state>
...
...
bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_router_js.js
View file @
f9435ae1
/*global window, rJS, jIO, URI, location, console, document, RSVP, loopEventListener, navigator, XMLHttpRequest, ProgressEvent
*/
/*jslint nomen: true, indent: 2
, maxerr: 15
*/
/*global window, rJS, jIO, URI, location, console, document, RSVP, loopEventListener, navigator, XMLHttpRequest, ProgressEvent*/
/*jslint nomen: true, indent: 2*/
(
function
(
window
,
rJS
)
{
"
use strict
"
;
...
...
@@ -12,13 +12,10 @@
function
get_jio_cache_storage
(
name
)
{
return
{
type
:
"
query
"
,
sub_storage
:
{
type
:
"
uuid
"
,
sub_storage
:
{
type
:
"
indexeddb
"
,
database
:
'
officejs_
'
+
name
+
'
_cache_erp5
'
}
}
};
}
...
...
@@ -139,7 +136,7 @@
return
jIO
.
createJIO
({
type
:
"
replicate
"
,
query
:
{
query
:
'
(portal_type: ("Web Style", "Web Page", "Web Script")) AND
'
+
query
:
'
reference: "%" AND
(portal_type: ("Web Style", "Web Page", "Web Script")) AND
'
+
erp5_query
+
modification_date
,
limit
:
[
0
,
1234567890
]
},
...
...
@@ -151,26 +148,22 @@
check_remote_modification
:
true
,
check_remote_creation
:
true
,
check_remote_deletion
:
true
,
local_sub_storage
:
{
type
:
"
attachasproperty
"
,
map
:
{
text_content
:
{
body_name
:
"
text_content
"
,
content_type_name
:
"
content_type
"
},
data
:
{
body_name
:
"
data
"
,
content_type_name
:
"
content_type
"
}
},
sub_storage
:
get_jio_cache_storage
(
name
)
},
//use_bulk_get: true,
use_bulk
:
false
,
local_sub_storage
:
get_jio_cache_storage
(
name
),
remote_sub_storage
:
{
type
:
"
mapping
"
,
sub_storage
:
{
type
:
"
erp5
"
,
url
:
(
new
URI
(
"
hateoasnoauth
"
))
.
absoluteTo
(
location
.
href
)
.
toString
(),
default_view_reference
:
"
jio_view
"
},
mapping_dict
:
{
"
id
"
:
{
"
equal
"
:
"
url_string
"
,
"
default_property
"
:
"
reference
"
}}
}
});
}
...
...
bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_router_js.xml
View file @
f9435ae1
...
...
@@ -224,7 +224,7 @@
</item>
<item>
<key>
<string>
serial
</string>
</key>
<value>
<string>
955.
22065.61366.57770
</string>
</value>
<value>
<string>
955.
40145.23133.18397
</string>
</value>
</item>
<item>
<key>
<string>
state
</string>
</key>
...
...
@@ -242,7 +242,7 @@
</tuple>
<state>
<tuple>
<float>
14
79378360.5
1
</float>
<float>
14
80578663.2
1
</float>
<string>
UTC
</string>
</tuple>
</state>
...
...
bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_serviceworker_js.js
View file @
f9435ae1
/*jslint indent: 2*/
/*global self, caches, importScripts, fetch, Promise, Request, Response, jIO, console, Headers, URI, location*/
/*global self, caches, importScripts, fetch,
Promise, Request, Response, jIO, console, Headers, URI, location, RSVP*/
var
global
=
self
,
window
=
self
;
(
function
(
self
,
fetch
)
{
...
...
@@ -52,26 +53,11 @@ var global = self,
// 2. readonly cache for end user
self
.
jio_erp5_cache_storage
=
{
type
:
"
memoryindex
"
,
select_list
:
[
'
reference
'
,
'
url_string
'
],
index
:
{
url_string
:
null
,
reference
:
function
(
obj
)
{
if
(
!
obj
.
url_string
)
{
return
obj
.
reference
;
}
}
},
sub_storage
:
{
type
:
"
query
"
,
sub_storage
:
{
type
:
"
uuid
"
,
sub_storage
:
{
type
:
"
indexeddb
"
,
database
:
self
.
jio_cache
.
name
+
'
_erp5
'
}
}
}
};
// sync in service worker not work.
// erp5storage not support fetch.
...
...
@@ -80,8 +66,7 @@ var global = self,
type
:
"
replicate
"
,
// XXX This drop the signature lists...
query
:
{
query
:
'
(portal_type: ("Web Style", "Web Page", "Web Script")) AND
'
+
self
.
jio_cache
.
erp5_query
,
query
:
self
.
jio_cache
.
erp5_query
,
limit
:
[
0
,
1234567890
]
},
use_remote_post
:
true
,
...
...
@@ -92,20 +77,25 @@ var global = self,
check_remote_modification
:
true
,
check_remote_creation
:
true
,
check_remote_deletion
:
true
,
local_sub_storage
:
{
type
:
"
attachasproperty
"
,
map
:
{
text_content
:
"
text_content
"
,
data
:
"
data
"
},
sub_storage
:
self
.
jio_erp5_cache_storage
},
use_bulk
:
false
,
local_sub_storage
:
self
.
jio_erp5_cache_storage
,
remote_sub_storage
:
{
type
:
"
mapping
"
,
sub_storage
:
{
type
:
"
erp5
"
,
url
:
(
new
URI
(
"
hateoas
"
))
url
:
(
new
URI
(
"
hateoasnoauth
"
))
.
absoluteTo
(
location
.
href
)
.
toString
(),
default_view_reference
:
"
jio_view
"
},
mapping_dict
:
{
"
id
"
:
{
"
equal
"
:
"
url_string
"
,
"
default_property
"
:
"
reference
"
}},
query
:
{
"
query
"
:
'
reference: "%" AND (portal_type: ("Web Style", "Web Page", "Web Script"))
'
}
}
});
}
else
{
...
...
@@ -155,7 +145,7 @@ var global = self,
},
is_excluded_url
=
function
(
url
)
{
var
prefix
,
i
;
for
(
i
=
0
;
i
<
exclude_urls
.
length
;
i
++
)
{
for
(
i
=
0
;
i
<
exclude_urls
.
length
;
i
+=
1
)
{
prefix
=
exclude_urls
[
i
];
if
(
url
===
prefix
)
{
return
true
;
...
...
@@ -166,27 +156,12 @@ var global = self,
}
return
false
;
},
get_mapped_url
=
function
(
url
)
{
var
prefix
,
prefix_id
,
key
;
for
(
key
in
map_url2url
)
{
if
(
map_url2url
.
hasOwnProperty
(
key
))
{
if
(
url
===
key
)
{
return
map_url2url
[
key
];
}
if
(
url
.
startsWith
(
key
))
{
return
url
.
replace
(
key
,
map_url2url
[
key
]);
}
}
}
},
get_relative_url
=
function
(
url
)
{
var
prefix
,
relative_url
,
i
,
prefix_id
;
for
(
i
=
0
;
i
<
websections_url
.
length
;
i
++
)
{
for
(
i
=
0
;
i
<
websections_url
.
length
;
i
+=
1
)
{
prefix
=
websections_url
[
i
];
if
(
url
.
startsWith
(
prefix
))
{
prefix_id
=
map_url2id_prefix
[
prefix
];
...
...
@@ -196,20 +171,19 @@ var global = self,
relative_url
=
url
.
replace
(
prefix
,
prefix_id
);
if
(
relative_url
)
{
return
relative_url
;
}
else
{
return
url
;
}
return
url
;
}
}
return
url
;
},
get_from_cache_storage
=
function
(
url
,
storage
)
{
var
jio_key
=
get_relative_url
(
url
)
;
var
jio_key
=
url
;
if
(
!
storage
)
{
storage
=
self
.
jio_cache_storage
;
}
return
new
Promise
(
function
(
resolve
,
reject
)
{
storage
.
getAttachment
(
jio_key
,
'
body
'
)
storage
.
getAttachment
(
jio_key
,
"
body
"
)
.
push
(
function
(
body
)
{
resolve
(
new
Response
(
body
,
{
'
headers
'
:
{
...
...
@@ -222,66 +196,20 @@ var global = self,
});
});
},
get_specific_url
=
function
(
url
)
{
var
prefix
,
prefix_id
,
i
;
for
(
i
=
0
;
i
<
websections_url
.
length
;
i
++
)
{
prefix
=
websections_url
[
i
];
if
(
url
.
startsWith
(
prefix
))
{
prefix_id
=
map_url2id_prefix
[
prefix
];
if
(
prefix_id
!==
""
)
{
return
url
.
replace
(
prefix
,
prefix_id
+
'
/
'
);
}
break
;
}
}
},
find_and_get
=
function
(
query
,
storage
)
{
if
(
!
storage
)
{
storage
=
self
.
jio_dev_storage
;
}
query
.
limit
=
[
0
,
1
];
query
.
select_list
=
[
'
portal_type
'
];
return
storage
.
allDocs
(
query
)
.
push
(
function
(
result
)
{
if
(
result
.
data
.
total_rows
==
1
)
{
return
{
id
:
result
.
data
.
rows
[
0
].
id
,
portal_type
:
result
.
data
.
rows
[
0
].
value
.
portal_type
};
}
else
{
throw
{
status_code
:
404
};
}
});
},
get_from_storage
=
function
(
url
,
storage
)
{
var
url_string
=
get_specific_url
(
url
),
url_object
=
new
URI
(
url
),
key
,
reference
=
url_object
.
filename
();
if
(
!
storage
)
{
storage
=
self
.
jio_dev_storage
;
}
return
new
Promise
(
function
(
resolve
,
reject
)
{
var
find_queue
;
if
(
url_string
!==
undefined
)
{
key
=
storage
.
__storage
.
_find_key
(
'
url_string
'
,
url_string
);
//if (!self.jio_cache.development_mode && !key) {
// key = storage.__storage._find_key('reference', reference);
//}
}
else
if
(
reference
===
get_relative_url
(
url
))
{
key
=
storage
.
__storage
.
_find_key
(
'
reference
'
,
reference
);
}
if
(
!
key
)
{
if
(
!
url
)
{
reject
({
status_code
:
404
});
return
;
}
find_queue
=
storage
.
getAttachment
(
key
,
'
text_content
'
)
storage
.
get
(
url
)
.
push
(
function
(
body
)
{
resolve
(
new
Response
(
body
,
{
resolve
(
new
Response
(
body
.
text_content
,
{
'
headers
'
:
{
'
content-type
'
:
body
.
type
'
content-type
'
:
body
.
content_
type
}
}));
})
...
...
@@ -357,7 +285,8 @@ var global = self,
metadata.portal_type = portal_type;
}*/
if
(
!
portal_type
)
{
console
.
log
(
'
content_type
'
+
content_type
+
'
not supported:
'
+
url
);
console
.
log
(
'
content_type
'
+
content_type
+
'
not supported:
'
+
url
);
return
resolve
();
}
self
.
jio_dev_storage
.
put
(
jio_key
,
metadata
)
...
...
@@ -378,9 +307,8 @@ var global = self,
});
});
});
}
else
{
return
Promise
.
resolve
();
}
return
Promise
.
resolve
();
};
(
function
()
{
...
...
@@ -403,8 +331,8 @@ var global = self,
}());
// TODO: generate from special websections current website
map_url2id_prefix
[
site_url
+
'
rjsunsafe/ooffice_fonts/
'
]
=
'
ooffice_fonts
'
;
map_url2id_prefix
[
site_url
+
'
rjsunsafe/ooffice/
'
]
=
'
ooffice
'
;
//
map_url2id_prefix[site_url + 'rjsunsafe/ooffice_fonts/'] = 'ooffice_fonts';
//
map_url2id_prefix[site_url + 'rjsunsafe/ooffice/'] = 'ooffice';
map_url2id_prefix
[
site_url
+
'
rjsunsafe/
'
]
=
''
;
map_url2id_prefix
[
site_url
]
=
''
;
map_url2id_prefix
[
'
https:
'
]
=
''
;
...
...
@@ -412,9 +340,12 @@ var global = self,
exclude_urls
.
push
(
site_url
+
'
hateoas
'
);
exclude_urls
.
push
(
site_url
+
'
hateoasnoauth
'
);
map_url2url
[
site_url
+
'
rjsunsafe/ooffice/apps/
'
]
=
'
https://localhost/OfficeWebDeploy/apps/
'
;
map_url2url
[
site_url
+
'
rjsunsafe/ooffice/sdkjs/
'
]
=
'
https://localhost/OfficeWebDeploy/sdkjs/
'
;
map_url2url
[
site_url
+
'
rjsunsafe/ooffice/vendor/
'
]
=
'
https://localhost/OfficeWebDeploy/vendor/
'
;
map_url2url
[
site_url
+
'
rjsunsafe/ooffice/apps/
'
]
=
'
https://localhost/OfficeWebDeploy/apps/
'
;
map_url2url
[
site_url
+
'
rjsunsafe/ooffice/sdkjs/
'
]
=
'
https://localhost/OfficeWebDeploy/sdkjs/
'
;
map_url2url
[
site_url
+
'
rjsunsafe/ooffice/vendor/
'
]
=
'
https://localhost/OfficeWebDeploy/vendor/
'
;
(
function
()
{
var
url
;
...
...
@@ -471,15 +402,18 @@ var global = self,
var
modification_mark_exist
=
false
;
if
(
metadata
.
headers
.
ETag
!==
undefined
)
{
modification_mark_exist
=
true
;
request
.
headers
.
append
(
'
If-None-Match
'
,
metadata
.
headers
.
Etag
);
request
.
headers
.
append
(
'
If-None-Match
'
,
metadata
.
headers
.
Etag
);
}
else
if
(
metadata
.
headers
[
'
last-modified
'
]
!==
undefined
)
{
modification_mark_exist
=
true
;
request
.
headers
.
append
(
'
If-Modified-Since
'
,
metadata
.
headers
[
'
last-modified
'
]);
request
.
headers
.
append
(
'
If-Modified-Since
'
,
metadata
.
headers
[
'
last-modified
'
]);
}
if
(
modification_mark_exist
)
{
return
fetch
(
request
)
.
then
(
undefined
,
function
()
{
// We say 'file not changed' if downloading is not possible with additional header
// We say 'file not changed' if downloading is not
// possible with additional header
return
new
Response
(
null
,
{
status
:
304
});
});
}
...
...
@@ -493,7 +427,7 @@ var global = self,
result_jio_save
=
result_jio_save
.
then
(
resolve
);
}
return
Promise
.
resolve
();
}
else
{
}
return
response
.
metadata_w_blob
()
.
then
(
function
(
response
)
{
// files save one by one
...
...
@@ -525,7 +459,6 @@ var global = self,
}
return
Promise
.
resolve
();
});
}
});
});
})
...
...
@@ -541,106 +474,66 @@ var global = self,
self
.
jio_cache_fetch
=
function
(
event
)
{
var
url
=
event
.
request
.
url
,
mapped_url
,
relative_url
=
get_relative_url
(
url
),
specific_url
=
get_specific_url
(
url
)
||
relative_url
,
not_found_in_dev_storage
=
false
,
queue
;
url_string
,
not_found_in_dev_storage
=
false
;
if
(
is_excluded_url
(
url
))
{
queue
=
fetch
(
event
.
request
);
if
(
is_excluded_url
(
url
)
||
url
===
site_url
)
{
event
.
respondWith
(
fetch
(
event
.
request
)
);
}
else
{
mapped_url
=
get_mapped_url
(
url
);
if
(
self
.
jio_cache
.
development_mode
&&
mapped_url
)
{
queue
=
fetch
(
mapped_url
)
.
then
(
undefined
,
function
(
error
)
{
if
(
error
.
status_code
===
404
)
{
console
.
log
(
url
+
'
,
'
+
specific_url
+
'
not found by
'
+
mapped_url
+
'
storage
'
);
return
get_from_storage
(
url
,
self
.
jio_erp5_cache_storage
);
}
else
{
throw
error
;
}
})
.
then
(
undefined
,
function
(
error
)
{
if
(
error
.
status_code
===
404
)
{
console
.
log
(
url
+
'
,
'
+
specific_url
+
'
not found in erp5 cache storage
'
);
return
get_from_cache_storage
(
url
);
}
else
{
throw
error
;
}
})
.
then
(
function
(
response
)
{
if
(
response
.
ok
)
{
save_in_dev_storage
(
url
,
response
.
clone
());
//console.log('returned: ' + url);
return
response
;
}
else
{
debugger
;
}
})
.
then
(
undefined
,
function
(
error
)
{
console
.
log
(
error
);
});
}
else
{
queue
=
Promise
.
resolve
()
.
then
(
function
()
{
url_string
=
get_relative_url
(
url
);
event
.
respondWith
(
new
RSVP
.
Queue
()
.
push
(
function
()
{
if
(
self
.
jio_cache
.
development_mode
)
{
// 1 level storage development
return
get_from_storage
(
url
,
self
.
jio_dev_storage
);
}
else
{
throw
{
status_code
:
404
};
return
get_from_storage
(
url_string
,
self
.
jio_dev_storage
);
}
throw
{
status_code
:
404
};
})
.
then
(
undefined
,
function
(
error
)
{
.
push
(
undefined
,
function
(
error
)
{
if
(
error
.
status_code
===
404
)
{
if
(
self
.
jio_cache
.
development_mode
)
{
console
.
log
(
url
+
'
,
'
+
specific_
url
+
'
not found in dev storage
'
);
console
.
log
(
url
+
'
not found in dev storage
'
);
not_found_in_dev_storage
=
true
;
}
// 2 level storage from erp5
return
get_from_storage
(
url
,
self
.
jio_erp5_cache_storage
);
}
else
{
throw
error
;
return
get_from_storage
(
url_string
,
self
.
jio_erp5_cache_storage
);
}
throw
error
;
})
.
then
(
undefined
,
function
(
error
)
{
.
push
(
undefined
,
function
(
error
)
{
if
(
error
.
status_code
===
404
)
{
console
.
log
(
url
+
'
,
'
+
specific_
url
+
'
not found in erp5 cache storage
'
);
console
.
log
(
url
+
'
not found in erp5 cache storage
'
);
// 3 level cache urls one for all aplications
return
get_from_cache_storage
(
url
);
}
else
{
throw
error
;
return
get_from_cache_storage
(
url_string
);
}
throw
error
;
})
.
then
(
undefined
,
function
(
error
)
{
.
push
(
undefined
,
function
(
error
)
{
if
(
error
.
status_code
===
404
)
{
console
.
log
(
url
+
'
,
'
+
relative_
url
+
'
not found in cache storage
'
);
console
.
log
(
url
+
'
not found in cache storage
'
);
// fetch
return
fetch
(
event
.
request
);
}
else
{
throw
error
;
}
throw
error
;
})
.
then
(
function
(
response
)
{
.
push
(
function
(
response
)
{
if
(
response
.
ok
)
{
if
(
not_found_in_dev_storage
)
{
save_in_dev_storage
(
url
,
response
.
clone
());
save_in_dev_storage
(
url_string
,
response
.
clone
());
}
//console.log('returned: ' + url);
}
return
response
;
})
.
then
(
undefined
,
function
(
error
)
{
.
push
(
undefined
,
function
(
error
)
{
console
.
log
(
error
);
});
}
}));
}
event
.
respondWith
(
queue
);
};
self
.
jio_cache_activate
=
function
(
event
)
{
/* Just like with the install event, event.waitUntil blocks activate on a
promise.
Activation will fail unless the promise is fulfilled.
/* Just like with the install event, event.waitUntil blocks activate on a
promise.
Activation will fail unless the promise is fulfilled.
*/
event
.
waitUntil
(
self
.
clients
.
claim
());
};
...
...
bt5/erp5_officejs/PathTemplateItem/web_page_module/gadget_officejs_serviceworker_js.xml
View file @
f9435ae1
...
...
@@ -243,7 +243,7 @@
</item>
<item>
<key>
<string>
serial
</string>
</key>
<value>
<string>
955.
630.63038.16349
</string>
</value>
<value>
<string>
955.
40147.13377.15940
</string>
</value>
</item>
<item>
<key>
<string>
state
</string>
</key>
...
...
@@ -261,7 +261,7 @@
</tuple>
<state>
<tuple>
<float>
14
78729480.3
</float>
<float>
14
80529399.17
</float>
<string>
UTC
</string>
</tuple>
</state>
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment