Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
O
officejs
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
nexedi
officejs
Commits
518161fb
Commit
518161fb
authored
Aug 19, 2011
by
François Billioud
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
add JIOStorage management
parent
594bdd07
Changes
2
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
206 additions
and
146 deletions
+206
-146
UNGProject/js/theme.js
UNGProject/js/theme.js
+142
-105
UNGProject/js/ung.js
UNGProject/js/ung.js
+64
-41
No files found.
UNGProject/js/theme.js
View file @
518161fb
This diff is collapsed.
Click to expand it.
UNGProject/js/ung.js
View file @
518161fb
...
@@ -10,35 +10,41 @@ setCurrentDocumentID = function(ID) {return localStorage.setItem("currentDocumen
...
@@ -10,35 +10,41 @@ setCurrentDocumentID = function(ID) {return localStorage.setItem("currentDocumen
/**
/**
* class DocumentList
* class DocumentList
* This class provides methods to manipulate the list of documents of the current user
* This class provides methods to manipulate the list of documents of the current user
* @param arg : a documentList json object to load
* the list object is the documentList returned by the storage.
* the detailedList object is the synchronized list containing more detailed information about documents
* @param documentList : documents information loaded from the storage
*/
*/
var
DocumentList
=
function
(
arg
)
{
var
DocumentList
=
function
(
documentList
)
{
//List.call(this);
if
(
sessionStorage
.
documentList
)
{
//load from sessionStorage
if
(
arg
)
{
this
.
load
(
JSON
.
parse
(
sessionStorage
.
documentList
));
this
.
load
(
arg
);
this
.
load
(
new
List
(
arg
,
JSONDocument
));
this
.
selectionList
=
new
List
(
arg
.
selectionList
);
//load methods of selectionList
}
}
else
{
else
{
List
.
call
(
this
);
if
(
documentList
)
{
for
(
var
doc
in
documentList
)
{
this
.
documentList
[
doc
]
=
new
JSONDocument
(
documentList
[
doc
]);
}
}
else
{
this
.
documentList
=
{}}
this
.
list
=
getCurrentStorage
().
getDocumentList
();
this
.
displayInformation
=
{};
this
.
displayInformation
=
{};
this
.
displayInformation
.
page
=
1
;
this
.
displayInformation
.
page
=
1
;
this
.
selectionList
=
new
List
()
;
this
.
selectionList
=
[]
;
}
}
}
}
DocumentList
.
prototype
=
new
Lis
t
();
DocumentList
.
prototype
=
new
UngObjec
t
();
DocumentList
.
prototype
.
load
({
DocumentList
.
prototype
.
load
({
removeDocument
:
function
(
doc
)
{
removeDocument
:
function
(
fileName
)
{
var
i
=
this
.
find
(
doc
);
getCurrentStorage
().
remove
(
fileName
)
//delete the file
this
.
get
(
i
).
remove
()
//delete the file
delete
this
.
list
[
fileName
];
//remove from the list
this
.
remove
(
i
);
//remove from the list
delete
this
.
detailedList
[
fileName
];
//
getCurrentStorage
()
.
save
();
//save changes
this
.
save
();
//save changes
},
},
getList
:
function
()
{
return
this
.
list
},
getDetailedList
:
function
()
{
return
this
.
detailedList
},
getSelectionList
:
function
()
{
return
this
.
selectionList
;},
getSelectionList
:
function
()
{
return
this
.
selectionList
;},
resetSelectionList
:
function
()
{
resetSelectionList
:
function
()
{
this
.
selectionList
=
new
List
()
;
this
.
selectionList
=
[]
;
//display consequences
//display consequences
for
(
var
i
=
this
.
getDisplayInformation
().
first
-
1
;
i
<
this
.
getDisplayInformation
().
last
;
i
++
)
{
for
(
var
i
=
this
.
getDisplayInformation
().
first
-
1
;
i
<
this
.
getDisplayInformation
().
last
;
i
++
)
{
...
@@ -47,9 +53,17 @@ DocumentList.prototype.load({
...
@@ -47,9 +53,17 @@ DocumentList.prototype.load({
$
(
"
span#selected_row_number a
"
).
html
(
0
);
//display the selected row number
$
(
"
span#selected_row_number a
"
).
html
(
0
);
//display the selected row number
},
},
checkAll
:
function
()
{
checkAll
:
function
()
{
this
.
selectionList
=
new
List
();
this
.
selectionList
=
[];
for
(
var
i
=
0
;
i
<
this
.
size
();
i
++
)
{
var
list
=
toArray
(
this
.
getList
());
this
.
getSelectionList
().
add
(
this
.
get
(
i
));
var
begin
=
0
;
var
end
=
list
.
length
;
if
(
getCurrentUser
().
getSetting
(
"
checkAllMethod
"
)
==
"
page
"
)
{
begin
=
this
.
getDisplayInformation
().
first
-
1
;
end
=
this
.
getDisplayInformation
().
last
;
}
for
(
var
i
=
begin
;
i
<
end
;
i
++
)
{
this
.
addToSelection
(
list
[
i
].
fileName
);
}
}
//display consequences
//display consequences
...
@@ -58,12 +72,19 @@ DocumentList.prototype.load({
...
@@ -58,12 +72,19 @@ DocumentList.prototype.load({
}
}
$
(
"
span#selected_row_number a
"
).
html
(
this
.
size
());
//display the selected row number
$
(
"
span#selected_row_number a
"
).
html
(
this
.
size
());
//display the selected row number
},
},
addToSelection
:
function
(
fileName
)
{
this
.
getSelectionList
().
push
(
fileName
);
},
removeFromSelection
:
function
(
fileName
)
{
var
selection
=
getDocumentList
().
getSelectionList
();
selection
.
splice
(
selection
.
indexOf
(
fileName
),
1
);
},
deleteSelectedDocuments
:
function
()
{
deleteSelectedDocuments
:
function
()
{
var
selection
=
this
.
getSelectionList
();
var
selection
=
this
.
getSelectionList
();
while
(
!
selection
.
isEmpty
()
)
{
while
(
selection
.
length
>
0
)
{
var
doc
=
selection
.
pop
();
var
fileName
=
selection
.
pop
();
this
.
removeDocument
(
doc
);
this
.
removeDocument
(
fileName
);
}
}
this
.
display
();
this
.
display
();
},
},
...
@@ -87,17 +108,20 @@ DocumentList.prototype.load({
...
@@ -87,17 +108,20 @@ DocumentList.prototype.load({
},
},
/* display the list of documents in the web page */
/* display the list of documents in the web page */
displayContent
:
function
()
{
displayContent
:
function
()
{
//display the list of document itself
$
(
"
table.listbox tbody
"
).
html
(
""
);
//empty the previous displayed list
$
(
"
table.listbox tbody
"
).
html
(
""
);
//empty the previous displayed list
var
list
=
toArray
(
this
.
getList
());
var
detailedList
=
this
.
getDetailedList
();
for
(
var
i
=
this
.
getDisplayInformation
().
first
-
1
;
i
<
this
.
getDisplayInformation
().
last
;
i
++
)
{
for
(
var
i
=
this
.
getDisplayInformation
().
first
-
1
;
i
<
this
.
getDisplayInformation
().
last
;
i
++
)
{
var
doc
=
this
.
get
(
i
);
var
fileName
=
list
[
i
].
fileName
;
var
ligne
=
new
Line
(
doc
,
i
);
if
(
!
detailedList
[
fileName
]
||
new
Date
(
detailedList
[
fileName
].
lastModification
+
1000
)
<
new
Date
(
list
[
i
].
lastModify
))
{
updateDocumentInformation
(
fileName
)}
ligne
.
updateHTML
();
var
line
=
new
Line
(
doc
,
i
);
ligne
.
display
();
line
.
updateHTML
();
if
(
this
.
getSelectionList
().
contains
(
doc
))
{
ligne
.
setSelected
(
true
);}
//check the box if selected
line
.
display
();
if
(
this
.
getSelectionList
().
indexOf
(
doc
.
fileName
))
{
line
.
setSelected
(
true
);}
//check the box if selected
}
}
},
},
displayListInformation
:
function
()
{
displayListInformation
:
function
()
{
//display number of records, first displayed document, last displayed document...
if
(
this
.
size
()
>
0
)
{
if
(
this
.
size
()
>
0
)
{
$
(
"
div.listbox-number-of-records
"
).
css
(
"
display
"
,
"
inline
"
);
$
(
"
div.listbox-number-of-records
"
).
css
(
"
display
"
,
"
inline
"
);
...
@@ -108,7 +132,7 @@ DocumentList.prototype.load({
...
@@ -108,7 +132,7 @@ DocumentList.prototype.load({
}
}
else
{
$
(
"
div.listbox-number-of-records
"
).
css
(
"
display
"
,
"
none
"
);}
else
{
$
(
"
div.listbox-number-of-records
"
).
css
(
"
display
"
,
"
none
"
);}
},
},
displayNavigationElements
:
function
()
{
displayNavigationElements
:
function
()
{
//display buttons first-page, previous, next, last-page
var
lastPage
=
this
.
getDisplayInformation
().
lastPage
;
var
lastPage
=
this
.
getDisplayInformation
().
lastPage
;
var
disp
=
function
(
element
,
bool
)
{
var
disp
=
function
(
element
,
bool
)
{
bool
?
$
(
element
).
css
(
"
display
"
,
"
inline
"
)
:
$
(
element
).
css
(
"
display
"
,
"
none
"
);
bool
?
$
(
element
).
css
(
"
display
"
,
"
inline
"
)
:
$
(
element
).
css
(
"
display
"
,
"
none
"
);
...
@@ -132,13 +156,12 @@ DocumentList.prototype.load({
...
@@ -132,13 +156,12 @@ DocumentList.prototype.load({
},
},
/* update the ith document information */
/* update the ith document information */
updateDocumentInformation
:
function
(
i
)
{
updateDocumentInformation
:
function
(
fileName
)
{
var
list
=
this
;
var
list
=
this
.
getDetailedList
();
var
doc
=
list
.
get
(
i
);
getCurrentStorage
().
getDocument
(
fileName
,
function
(
doc
)
{
getCurrentStorage
().
getDocument
(
getDocumentAddress
(
doc
),
function
(
data
)
{
list
[
fileName
]
=
doc
;
doc
.
load
(
data
);
//todo : replace by data.header
list
[
fileName
].
fileName
=
fileName
;
doc
.
setContent
(
""
);
//
doc
.
setContent
(
""
);
list
.
set
(
i
,
doc
);
});
});
},
},
/* update the document to be displayed */
/* update the document to be displayed */
...
@@ -172,7 +195,7 @@ var Line = function(doc, i) {
...
@@ -172,7 +195,7 @@ var Line = function(doc, i) {
Line
.
prototype
=
{
Line
.
prototype
=
{
getDocument
:
function
()
{
return
this
.
document
;},
getDocument
:
function
()
{
return
this
.
document
;},
getID
:
function
()
{
return
this
.
ID
;},
getID
:
function
()
{
return
this
.
ID
;},
getType
:
function
()
{
return
this
.
document
.
getType
()
?
this
.
document
.
getType
()
:
"
other
"
;},
getType
:
function
()
{
return
this
.
document
.
getType
()
||
"
other
"
;},
getHTML
:
function
()
{
return
this
.
html
;},
getHTML
:
function
()
{
return
this
.
html
;},
setHTML
:
function
(
newHTML
)
{
this
.
html
=
newHTML
;},
setHTML
:
function
(
newHTML
)
{
this
.
html
=
newHTML
;},
setSelected
:
function
(
bool
)
{
$
(
"
tr td.listbox-table-select-cell input#
"
+
this
.
getID
()).
attr
(
"
checked
"
,
bool
)},
setSelected
:
function
(
bool
)
{
$
(
"
tr td.listbox-table-select-cell input#
"
+
this
.
getID
()).
attr
(
"
checked
"
,
bool
)},
...
@@ -182,16 +205,16 @@ Line.prototype = {
...
@@ -182,16 +205,16 @@ Line.prototype = {
/* add the document of this line to the list of selected documents */
/* add the document of this line to the list of selected documents */
addToSelection
:
function
()
{
addToSelection
:
function
()
{
getDocumentList
().
getSelectionList
().
add
(
this
.
getDocument
()
);
getDocumentList
().
addToSelection
(
this
.
getDocument
().
fileName
);
},
},
/* remove the document of this line from the list of selected documents */
/* remove the document of this line from the list of selected documents */
removeFromSelection
:
function
()
{
removeFromSelection
:
function
()
{
getDocumentList
().
getSelectionList
().
removeElement
(
this
.
getDocument
()
);
getDocumentList
().
removeFromSelection
(
this
.
getDocument
().
fileName
);
},
},
/* check or uncheck the line */
/* check or uncheck the line */
changeState
:
function
()
{
changeState
:
function
()
{
this
.
isSelected
()
?
this
.
addToSelection
()
:
this
.
removeFromSelection
();
this
.
isSelected
()
?
this
.
addToSelection
()
:
this
.
removeFromSelection
();
$
(
"
span#selected_row_number a
"
).
html
(
getDocumentList
().
getSelectionList
().
size
()
);
//display the selected row number
$
(
"
span#selected_row_number a
"
).
html
(
getDocumentList
().
getSelectionList
().
length
);
//display the selected row number
},
},
/* load the document information in the html of a default line */
/* load the document information in the html of a default line */
...
...
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