Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
W
web-apps
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
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Boris Kocherov
web-apps
Commits
041d617b
Commit
041d617b
authored
May 17, 2016
by
Julia Radzhabova
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[SSE] В контекстное меню добавлена возможность фильтрации ячеек.
parent
503ee98e
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
85 additions
and
10 deletions
+85
-10
apps/spreadsheeteditor/main/app/controller/DocumentHolder.js
apps/spreadsheeteditor/main/app/controller/DocumentHolder.js
+52
-8
apps/spreadsheeteditor/main/app/view/AutoFilterDialog.js
apps/spreadsheeteditor/main/app/view/AutoFilterDialog.js
+1
-1
apps/spreadsheeteditor/main/app/view/DocumentHolder.js
apps/spreadsheeteditor/main/app/view/DocumentHolder.js
+32
-1
No files found.
apps/spreadsheeteditor/main/app/controller/DocumentHolder.js
View file @
041d617b
...
...
@@ -152,6 +152,8 @@ define([
view
.
pmiInsertCells
.
menu
.
on
(
'
item:click
'
,
_
.
bind
(
me
.
onInsertCells
,
me
));
view
.
pmiDeleteCells
.
menu
.
on
(
'
item:click
'
,
_
.
bind
(
me
.
onDeleteCells
,
me
));
view
.
pmiSortCells
.
menu
.
on
(
'
item:click
'
,
_
.
bind
(
me
.
onSortCells
,
me
));
view
.
pmiFilterCells
.
menu
.
on
(
'
item:click
'
,
_
.
bind
(
me
.
onFilterCells
,
me
));
view
.
pmiReapply
.
menu
.
on
(
'
item:click
'
,
_
.
bind
(
me
.
onReapply
,
me
));
view
.
pmiClear
.
menu
.
on
(
'
item:click
'
,
_
.
bind
(
me
.
onClear
,
me
));
view
.
pmiSelectTable
.
menu
.
on
(
'
item:click
'
,
_
.
bind
(
me
.
onSelectTable
,
me
));
view
.
pmiInsertTable
.
menu
.
on
(
'
item:click
'
,
_
.
bind
(
me
.
onInsertTable
,
me
));
...
...
@@ -343,6 +345,41 @@ define([
}
},
onFilterCells
:
function
(
menu
,
item
)
{
if
(
this
.
api
)
{
var
autoFilterObject
=
new
Asc
.
AutoFiltersOptions
(),
filterObj
=
new
Asc
.
AutoFilterObj
();
if
(
item
.
value
>
0
)
{
filterObj
.
asc_setFilter
(
new
Asc
.
ColorFilter
());
filterObj
.
asc_setType
(
Asc
.
c_oAscAutoFilterTypes
.
ColorFilter
);
var
colorFilter
=
filterObj
.
asc_getFilter
();
colorFilter
.
asc_setCellColor
((
item
.
value
==
1
)
?
null
:
false
);
colorFilter
.
asc_setCColor
((
item
.
value
==
1
)
?
this
.
documentHolder
.
ssMenu
.
cellColor
:
this
.
documentHolder
.
ssMenu
.
fontColor
);
}
else
{
filterObj
.
asc_setFilter
(
new
Asc
.
CustomFilters
());
filterObj
.
asc_setType
(
Asc
.
c_oAscAutoFilterTypes
.
CustomFilters
);
var
customFilter
=
filterObj
.
asc_getFilter
();
customFilter
.
asc_setCustomFilters
([
new
Asc
.
CustomFilter
()]);
customFilter
.
asc_setAnd
(
true
);
var
customFilters
=
customFilter
.
asc_getCustomFilters
();
customFilters
[
0
].
asc_setOperator
(
Asc
.
c_oAscCustomAutoFilter
.
equals
);
// customFilters[0].asc_setVal('');
}
autoFilterObject
.
asc_setFilterObj
(
filterObj
);
this
.
api
.
asc_applyAutoFilterByType
(
autoFilterObject
);
Common
.
NotificationCenter
.
trigger
(
'
edit:complete
'
,
this
.
documentHolder
);
Common
.
component
.
Analytics
.
trackEvent
(
'
DocumentHolder
'
,
'
Filter Cells
'
);
}
},
onReapply
:
function
()
{
this
.
api
.
asc_applyAutoFilter
(
new
Asc
.
AutoFiltersOptions
());
},
onClear
:
function
(
menu
,
item
)
{
if
(
this
.
api
)
{
this
.
api
.
asc_emptyCells
(
item
.
value
);
...
...
@@ -1181,6 +1218,8 @@ define([
formatTableInfo
=
cellinfo
.
asc_getFormatTableInfo
(),
isintable
=
(
formatTableInfo
!==
null
);
documentHolder
.
ssMenu
.
formatTableName
=
(
isintable
)
?
formatTableInfo
.
asc_getTableName
()
:
null
;
documentHolder
.
ssMenu
.
cellColor
=
cellinfo
.
asc_getFill
().
asc_getColor
();
documentHolder
.
ssMenu
.
fontColor
=
cellinfo
.
asc_getFont
().
asc_getColor
();
documentHolder
.
pmiInsertEntire
.
setVisible
(
isrowmenu
||
iscolmenu
);
documentHolder
.
pmiInsertEntire
.
setCaption
((
isrowmenu
)
?
this
.
textInsertTop
:
this
.
textInsertLeft
);
...
...
@@ -1190,7 +1229,10 @@ define([
documentHolder
.
pmiSelectTable
.
setVisible
(
iscellmenu
&&
!
iscelledit
&&
isintable
);
documentHolder
.
pmiInsertTable
.
setVisible
(
iscellmenu
&&
!
iscelledit
&&
isintable
);
documentHolder
.
pmiDeleteTable
.
setVisible
(
iscellmenu
&&
!
iscelledit
&&
isintable
);
documentHolder
.
pmiSortCells
.
setVisible
((
iscellmenu
||
isallmenu
||
cansort
)
&&
!
iscelledit
&&
!
isintable
);
documentHolder
.
pmiSortCells
.
setVisible
((
iscellmenu
||
isallmenu
||
cansort
)
&&
!
iscelledit
);
documentHolder
.
pmiFilterCells
.
setVisible
((
iscellmenu
||
cansort
)
&&
!
iscelledit
);
documentHolder
.
pmiReapply
.
setVisible
((
iscellmenu
||
isallmenu
||
cansort
)
&&
!
iscelledit
);
documentHolder
.
ssMenu
.
items
[
12
].
setVisible
((
iscellmenu
||
isallmenu
||
cansort
)
&&
!
iscelledit
);
documentHolder
.
pmiInsFunction
.
setVisible
(
iscellmenu
||
insfunc
);
documentHolder
.
pmiAddNamedRange
.
setVisible
(
iscellmenu
&&
!
iscelledit
);
...
...
@@ -1218,7 +1260,7 @@ define([
documentHolder
.
pmiFreezePanes
.
setCaption
(
this
.
api
.
asc_getSheetViewSettings
().
asc_getIsFreezePane
()
?
documentHolder
.
textUnFreezePanes
:
documentHolder
.
textFreezePanes
);
/** coauthoring begin **/
documentHolder
.
ssMenu
.
items
[
1
3
].
setVisible
(
iscellmenu
&&
!
iscelledit
&&
this
.
permissions
.
canCoAuthoring
&&
this
.
permissions
.
canComments
);
documentHolder
.
ssMenu
.
items
[
1
6
].
setVisible
(
iscellmenu
&&
!
iscelledit
&&
this
.
permissions
.
canCoAuthoring
&&
this
.
permissions
.
canComments
);
documentHolder
.
pmiAddComment
.
setVisible
(
iscellmenu
&&
!
iscelledit
&&
this
.
permissions
.
canCoAuthoring
&&
this
.
permissions
.
canComments
);
/** coauthoring end **/
documentHolder
.
pmiCellMenuSeparator
.
setVisible
(
iscellmenu
||
isrowmenu
||
iscolmenu
||
isallmenu
||
insfunc
);
...
...
@@ -1236,17 +1278,19 @@ define([
documentHolder
.
pmiClear
.
menu
.
items
[
3
].
setVisible
(
!
this
.
permissions
.
isEditDiagram
);
documentHolder
.
pmiClear
.
menu
.
items
[
4
].
setVisible
(
!
this
.
permissions
.
isEditDiagram
);
var
filterInfo
=
cellinfo
.
asc_getAutoFilterInfo
();
filterInfo
=
(
filterInfo
)
?
filterInfo
.
asc_getIsApplyAutoFilter
()
:
false
;
documentHolder
.
pmiInsertCells
.
menu
.
items
[
0
].
setDisabled
(
filterInfo
);
documentHolder
.
pmiDeleteCells
.
menu
.
items
[
0
].
setDisabled
(
filterInfo
);
documentHolder
.
pmiInsertCells
.
menu
.
items
[
1
].
setDisabled
(
filterInfo
);
documentHolder
.
pmiDeleteCells
.
menu
.
items
[
1
].
setDisabled
(
filterInfo
);
var
filterInfo
=
cellinfo
.
asc_getAutoFilterInfo
(),
isApplyAutoFilter
=
(
filterInfo
)
?
filterInfo
.
asc_getIsApplyAutoFilter
()
:
false
;
filterInfo
=
(
filterInfo
)
?
filterInfo
.
asc_getIsAutoFilter
()
:
null
;
documentHolder
.
pmiInsertCells
.
menu
.
items
[
0
].
setDisabled
(
isApplyAutoFilter
);
documentHolder
.
pmiDeleteCells
.
menu
.
items
[
0
].
setDisabled
(
isApplyAutoFilter
);
documentHolder
.
pmiInsertCells
.
menu
.
items
[
1
].
setDisabled
(
isApplyAutoFilter
);
documentHolder
.
pmiDeleteCells
.
menu
.
items
[
1
].
setDisabled
(
isApplyAutoFilter
);
_
.
each
(
documentHolder
.
ssMenu
.
items
,
function
(
item
)
{
item
.
setDisabled
(
isCellLocked
);
});
documentHolder
.
pmiCopy
.
setDisabled
(
false
);
documentHolder
.
pmiSortCells
.
setDisabled
(
isCellLocked
||
(
filterInfo
==
null
));
if
(
showMenu
)
this
.
showPopupMenu
(
documentHolder
.
ssMenu
,
{},
event
);
}
else
if
(
this
.
permissions
.
isEditDiagram
&&
seltype
==
Asc
.
c_oAscSelectionType
.
RangeChartText
)
{
if
(
!
showMenu
&&
!
documentHolder
.
textInShapeMenu
.
isVisible
())
return
;
...
...
apps/spreadsheeteditor/main/app/view/AutoFilterDialog.js
View file @
041d617b
...
...
@@ -677,8 +677,8 @@ define([
this
.
miTextFilter
,
this
.
miFilterCellColor
,
this
.
miFilterFontColor
,
{
caption
:
'
--
'
},
this
.
miClear
,
{
caption
:
'
--
'
},
this
.
miReapply
]
});
...
...
apps/spreadsheeteditor/main/app/view/DocumentHolder.js
View file @
041d617b
...
...
@@ -239,6 +239,29 @@ define([
})
});
me
.
pmiFilterCells
=
new
Common
.
UI
.
MenuItem
({
caption
:
me
.
txtFilter
,
menu
:
new
Common
.
UI
.
Menu
({
menuAlign
:
'
tl-tr
'
,
items
:
[
{
caption
:
me
.
txtFilterValue
,
value
:
0
},{
caption
:
me
.
txtFilterCellColor
,
value
:
1
},{
caption
:
me
.
txtFilterFontColor
,
value
:
2
}
]
})
});
me
.
pmiReapply
=
new
Common
.
UI
.
MenuItem
({
caption
:
me
.
txtReapply
});
me
.
pmiInsFunction
=
new
Common
.
UI
.
MenuItem
({
caption
:
me
.
txtFormula
});
...
...
@@ -319,7 +342,10 @@ define([
me
.
pmiDeleteCells
,
me
.
pmiDeleteTable
,
me
.
pmiClear
,
{
caption
:
'
--
'
},
me
.
pmiSortCells
,
me
.
pmiFilterCells
,
me
.
pmiReapply
,
{
caption
:
'
--
'
},
me
.
pmiAddComment
,
me
.
pmiCellMenuSeparator
,
...
...
@@ -629,7 +655,12 @@ define([
insertColumnRightText
:
'
Insert Column Right
'
,
deleteRowText
:
'
Delete Row
'
,
deleteColumnText
:
'
Delete Column
'
,
deleteTableText
:
'
Delete Table
'
deleteTableText
:
'
Delete Table
'
,
txtFilter
:
'
Filter
'
,
txtFilterValue
:
'
Filter by Selected cell
\'
s value
'
,
txtFilterCellColor
:
'
Filter by cell
\'
s color
'
,
txtFilterFontColor
:
'
Filter by font color
'
,
txtReapply
:
'
Reapply
'
},
SSE
.
Views
.
DocumentHolder
||
{}));
});
\ No newline at end of file
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