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
0a98532b
Commit
0a98532b
authored
Dec 16, 2016
by
Alexander Yuzhin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[SE mobile] Add horizontal axis handlers of charts
parent
c90ffcc7
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
280 additions
and
58 deletions
+280
-58
apps/spreadsheeteditor/mobile/app/controller/edit/EditChart.js
...spreadsheeteditor/mobile/app/controller/edit/EditChart.js
+181
-53
apps/spreadsheeteditor/mobile/app/template/EditChart.template
.../spreadsheeteditor/mobile/app/template/EditChart.template
+99
-5
No files found.
apps/spreadsheeteditor/mobile/app/controller/edit/EditChart.js
View file @
0a98532b
...
...
@@ -329,15 +329,6 @@ define([
var
me
=
this
,
$vertAxisPage
=
$
(
'
.page[data-page=edit-chart-vertical-axis]
'
),
chartProperty
=
me
.
api
.
asc_getChartObject
(),
chartType
=
chartProperty
.
getType
(),
needReverse
=
(
chartType
==
Asc
.
c_oAscChartTypeSettings
.
hBarNormal
||
chartType
==
Asc
.
c_oAscChartTypeSettings
.
hBarStacked
||
chartType
==
Asc
.
c_oAscChartTypeSettings
.
hBarStackedPer
||
chartType
==
Asc
.
c_oAscChartTypeSettings
.
hBarNormal3d
||
chartType
==
Asc
.
c_oAscChartTypeSettings
.
hBarStacked3d
||
chartType
==
Asc
.
c_oAscChartTypeSettings
.
hBarStackedPer3d
),
verAxisProps
=
chartProperty
.
getVertAxisProps
(),
axisProps
=
(
verAxisProps
.
getAxisType
()
==
Asc
.
c_oAscAxisType
.
val
)
?
verAxisProps
:
chartProperty
.
getHorAxisProps
();
...
...
@@ -359,8 +350,6 @@ define([
})());
};
$
(
'
#edit-chart-vertical-axis-title
'
).
text
(
needReverse
?
me
.
textHorAxis
:
me
.
textVertAxis
);
// Axis
$
(
'
#edit-vertical-axis-min-val input
'
).
val
((
axisProps
.
getMinValRule
()
==
Asc
.
c_oAscValAxisRule
.
auto
)
?
null
:
axisProps
.
getMinVal
());
$
(
'
#edit-vertical-axis-max-val input
'
).
val
((
axisProps
.
getMaxValRule
()
==
Asc
.
c_oAscValAxisRule
.
auto
)
?
null
:
axisProps
.
getMaxVal
());
...
...
@@ -421,6 +410,8 @@ define([
]);
setValue
(
'
vertical-axis-label-pos
'
,
axisProps
.
getTickLabelsPos
());
me
.
updateAxisProps
(
chartProperty
.
getType
());
// Handlers
$
(
'
#edit-vertical-axis-min-val input
'
).
single
(
'
change
'
,
_
.
bind
(
me
.
onVerAxisMinValue
,
me
));
$
(
'
#edit-vertical-axis-max-val input
'
).
single
(
'
change
'
,
_
.
bind
(
me
.
onVerAxisMaxValue
,
me
));
...
...
@@ -434,19 +425,88 @@ define([
},
initHorAxisPage
:
function
()
{
var
chartType
=
_chartObject
.
get_ChartProperties
().
getType
();
var
me
=
this
,
$horAxisPage
=
$
(
'
.page[data-page=edit-chart-horizontal-axis]
'
),
chartProperty
=
me
.
api
.
asc_getChartObject
(),
horAxisProps
=
chartProperty
.
getHorAxisProps
(),
axisProps
=
(
horAxisProps
.
getAxisType
()
==
Asc
.
c_oAscAxisType
.
val
)
?
chartProperty
.
getVertAxisProps
()
:
horAxisProps
;
var
needReverse
=
(
chartType
==
Asc
.
c_oAscChartTypeSettings
.
hBarNormal
||
chartType
==
Asc
.
c_oAscChartTypeSettings
.
hBarStacked
||
chartType
==
Asc
.
c_oAscChartTypeSettings
.
hBarStackedPer
||
chartType
==
Asc
.
c_oAscChartTypeSettings
.
hBarNormal3d
||
chartType
==
Asc
.
c_oAscChartTypeSettings
.
hBarStacked3d
||
chartType
==
Asc
.
c_oAscChartTypeSettings
.
hBarStackedPer3d
||
chartType
==
Asc
.
c_oAscChartTypeSettings
.
scatter
);
var
setValue
=
function
(
id
,
value
)
{
var
textValue
=
$horAxisPage
.
find
(
'
select[name=
'
+
id
+
'
]
'
)
.
val
(
value
)
.
find
(
'
option[value=
'
+
value
+
'
]
'
)
.
text
();
$horAxisPage
.
find
(
'
#
'
+
id
+
'
.item-after
'
).
text
(
textValue
);
};
var
setOptions
=
function
(
selectName
,
options
)
{
$horAxisPage
.
find
(
'
select[name=
'
+
selectName
+
'
]
'
).
html
((
function
()
{
var
_options
=
[];
_
.
each
(
options
,
function
(
option
)
{
_options
.
push
(
Common
.
Utils
.
String
.
format
(
'
<option value="{0}">{1}</option>
'
,
option
.
value
,
option
.
display
));
});
return
_options
.
join
(
''
);
})());
};
// Cross
setOptions
(
'
horizontal-axis-cross
'
,
[
{
display
:
this
.
textAuto
,
value
:
Asc
.
c_oAscCrossesRule
.
auto
},
{
display
:
this
.
textValue
,
value
:
Asc
.
c_oAscCrossesRule
.
value
},
{
display
:
this
.
textMinValue
,
value
:
Asc
.
c_oAscCrossesRule
.
minValue
},
{
display
:
this
.
textMaxValue
,
value
:
Asc
.
c_oAscCrossesRule
.
maxValue
}
]);
var
crossValue
=
axisProps
.
getCrossesRule
();
setValue
(
'
horizontal-axis-cross
'
,
crossValue
);
if
(
crossValue
==
Asc
.
c_oAscCrossesRule
.
value
)
{
$
(
'
#edit-horizontal-axis-cross-value
'
).
css
(
'
display
'
,
'
block
'
);
$
(
'
#edit-horizontal-axis-cross-value input
'
).
val
(
axisProps
.
getCrosses
());
}
// Pos
setOptions
(
'
horizontal-axis-position
'
,
[
{
display
:
this
.
textOnTickMarks
,
value
:
Asc
.
c_oAscLabelsPosition
.
byDivisions
},
{
display
:
this
.
textBetweenTickMarks
,
value
:
Asc
.
c_oAscLabelsPosition
.
betweenDivisions
}
]);
setValue
(
'
horizontal-axis-position
'
,
axisProps
.
getLabelsPosition
());
$
(
'
#horizontal-axis-in-reverse input
'
).
prop
(
'
checked
'
,
axisProps
.
getInvertCatOrder
());
$
(
'
#edit-chart-horizontal-axis-title
'
).
text
(
needReverse
?
this
.
textVertAxis
:
this
.
textHorAxis
);
// Tick
var
tickOptions
=
[
{
display
:
this
.
textNone
,
value
:
Asc
.
c_oAscTickMark
.
TICK_MARK_NONE
},
{
display
:
this
.
textCross
,
value
:
Asc
.
c_oAscTickMark
.
TICK_MARK_CROSS
},
{
display
:
this
.
textIn
,
value
:
Asc
.
c_oAscTickMark
.
TICK_MARK_IN
},
{
display
:
this
.
textOut
,
value
:
Asc
.
c_oAscTickMark
.
TICK_MARK_OUT
}
];
setOptions
(
'
horizontal-axis-tick-major
'
,
tickOptions
);
setOptions
(
'
horizontal-axis-tick-minor
'
,
tickOptions
);
setValue
(
'
horizontal-axis-tick-major
'
,
axisProps
.
getMajorTickMark
());
setValue
(
'
horizontal-axis-tick-minor
'
,
axisProps
.
getMinorTickMark
());
// Label
setOptions
(
'
horizontal-axis-label-pos
'
,
[
{
display
:
this
.
textNone
,
value
:
Asc
.
c_oAscTickLabelsPos
.
TICK_LABEL_POSITION_NONE
},
{
display
:
this
.
textLow
,
value
:
Asc
.
c_oAscTickLabelsPos
.
TICK_LABEL_POSITION_LOW
},
{
display
:
this
.
textHigh
,
value
:
Asc
.
c_oAscTickLabelsPos
.
TICK_LABEL_POSITION_HIGH
},
{
display
:
this
.
textNextToAxis
,
value
:
Asc
.
c_oAscTickLabelsPos
.
TICK_LABEL_POSITION_NEXT_TO
}
]);
setValue
(
'
horizontal-axis-label-pos
'
,
axisProps
.
getTickLabelsPos
());
me
.
updateAxisProps
(
chartProperty
.
getType
());
// Handlers
$
(
'
#horizontal-axis-cross select
'
).
single
(
'
change
'
,
_
.
bind
(
me
.
onHorAxisCrossType
,
me
));
$
(
'
#edit-horizontal-axis-cross-value input
'
).
single
(
'
change
'
,
_
.
bind
(
me
.
onHorAxisCrossValue
,
me
));
$
(
'
#horizontal-axis-position select
'
).
single
(
'
change
'
,
_
.
bind
(
me
.
onHorAxisPos
,
me
));
$
(
'
#horizontal-axis-in-reverse input
'
).
single
(
'
change
'
,
_
.
bind
(
me
.
onHorAxisReverse
,
me
));
$
(
'
#horizontal-axis-tick-major select
'
).
single
(
'
change
'
,
_
.
bind
(
me
.
onHorAxisTickMajor
,
me
));
$
(
'
#horizontal-axis-tick-minor select
'
).
single
(
'
change
'
,
_
.
bind
(
me
.
onHorAxisTickMinor
,
me
));
$
(
'
#horizontal-axis-label-pos select
'
).
single
(
'
change
'
,
_
.
bind
(
me
.
onHorAxisLabelPos
,
me
));
},
initReorderPage
:
function
()
{
...
...
@@ -748,6 +808,79 @@ define([
this
.
_setVerticalAxisProp
(
axisProps
);
},
onHorAxisCrossType
:
function
(
e
)
{
var
value
=
$
(
e
.
currentTarget
).
val
(),
axisProps
=
this
.
_getHorizontalAxisProp
();
if
(
value
==
Asc
.
c_oAscCrossesRule
.
value
)
{
$
(
'
#edit-horizontal-axis-cross-value
'
).
css
(
'
display
'
,
'
block
'
);
$
(
'
#edit-horizontal-axis-cross-value input
'
).
val
(
axisProps
.
getCrosses
());
}
else
{
$
(
'
#edit-horizontal-axis-cross-value
'
).
css
(
'
display
'
,
'
none
'
);
}
axisProps
.
putCrossesRule
(
parseInt
(
value
));
this
.
_setHorizontalAxisProp
(
axisProps
);
},
onHorAxisCrossValue
:
function
(
e
)
{
var
value
=
$
(
e
.
currentTarget
).
val
(),
axisProps
=
this
.
_getHorizontalAxisProp
();
axisProps
.
putCrossesRule
(
Asc
.
c_oAscCrossesRule
.
value
);
axisProps
.
putCrosses
(
parseInt
(
value
));
this
.
_setHorizontalAxisProp
(
axisProps
);
},
onHorAxisPos
:
function
(
e
)
{
var
value
=
$
(
e
.
currentTarget
).
val
(),
axisProps
=
this
.
_getHorizontalAxisProp
();
axisProps
.
putLabelsPosition
(
parseInt
(
value
));
this
.
_setHorizontalAxisProp
(
axisProps
);
},
onHorAxisReverse
:
function
(
e
)
{
var
value
=
$
(
e
.
currentTarget
).
prop
(
'
checked
'
),
axisProps
=
this
.
_getHorizontalAxisProp
();
axisProps
.
putInvertCatOrder
(
value
);
this
.
_setHorizontalAxisProp
(
axisProps
);
},
onHorAxisTickMajor
:
function
(
e
)
{
var
value
=
$
(
e
.
currentTarget
).
val
(),
axisProps
=
this
.
_getHorizontalAxisProp
();
axisProps
.
putMajorTickMark
(
parseInt
(
value
));
this
.
_setHorizontalAxisProp
(
axisProps
);
},
onHorAxisTickMinor
:
function
(
e
)
{
var
value
=
$
(
e
.
currentTarget
).
val
(),
axisProps
=
this
.
_getHorizontalAxisProp
();
axisProps
.
putMinorTickMark
(
parseInt
(
value
));
this
.
_setHorizontalAxisProp
(
axisProps
);
},
onHorAxisLabelPos
:
function
(
e
)
{
var
value
=
$
(
e
.
currentTarget
).
val
(),
axisProps
=
this
.
_getHorizontalAxisProp
();
axisProps
.
putTickLabelsPos
(
parseInt
(
value
));
this
.
_setHorizontalAxisProp
(
axisProps
);
},
updateAxisProps
:
function
(
chartType
)
{
// var value = (chartType == Asc.c_oAscChartTypeSettings.lineNormal || chartType == Asc.c_oAscChartTypeSettings.lineStacked ||
// chartType == Asc.c_oAscChartTypeSettings.lineStackedPer || chartType == Asc.c_oAscChartTypeSettings.scatter);
...
...
@@ -759,33 +892,28 @@ define([
// this.chMarkers.setValue(this.chartSettings.getShowMarker(), true);
// this.cmbLines.setValue(this.chartSettings.getLine() ? (this.chartSettings.getSmooth() ? 2 : 1) : 0);
// }
//
// value = (chartType == Asc.c_oAscChartTypeSettings.pie || chartType == Asc.c_oAscChartTypeSettings.doughnut || chartType == Asc.c_oAscChartTypeSettings.pie3d);
// this.btnsCategory[2].setDisabled(value);
// this.btnsCategory[3].setDisabled(value);
// this.cmbHorShow.setDisabled(value);
// this.cmbVertShow.setDisabled(value);
// this.cmbHorTitle.setDisabled(value);
// this.cmbVertTitle.setDisabled(value);
// this.cmbHorGrid.setDisabled(value);
// this.cmbVertGrid.setDisabled(value);
//
// this.cmbHorShow.setValue(this.chartSettings.getShowHorAxis());
// this.cmbVertShow.setValue(this.chartSettings.getShowVerAxis());
// this.cmbHorTitle.setValue(this.chartSettings.getHorAxisLabel());
// this.cmbVertTitle.setValue(this.chartSettings.getVertAxisLabel());
// this.cmbHorGrid.setValue(this.chartSettings.getHorGridLines());
// this.cmbVertGrid.setValue(this.chartSettings.getVertGridLines());
//
// value = (chartType == Asc.c_oAscChartTypeSettings.barNormal3d || chartType == Asc.c_oAscChartTypeSettings.barStacked3d || chartType == Asc.c_oAscChartTypeSettings.barStackedPer3d ||
// chartType == Asc.c_oAscChartTypeSettings.hBarNormal3d || chartType == Asc.c_oAscChartTypeSettings.hBarStacked3d || chartType == Asc.c_oAscChartTypeSettings.hBarStackedPer3d ||
// chartType == Asc.c_oAscChartTypeSettings.barNormal3dPerspective);
// this.cmbAxisPos.setDisabled(value);
//
// value = (chartType == Asc.c_oAscChartTypeSettings.hBarNormal || chartType == Asc.c_oAscChartTypeSettings.hBarStacked || chartType == Asc.c_oAscChartTypeSettings.hBarStackedPer ||
// chartType == Asc.c_oAscChartTypeSettings.hBarNormal3d || chartType == Asc.c_oAscChartTypeSettings.hBarStacked3d || chartType == Asc.c_oAscChartTypeSettings.hBarStackedPer3d);
// this.btnsCategory[2].options.contentTarget = (value) ? 'id-chart-settings-dlg-hor' : 'id-chart-settings-dlg-vert';
// this.btnsCategory[3].options.contentTarget = (value || chartType == Asc.c_oAscChartTypeSettings.scatter) ? 'id-chart-settings-dlg-vert' : 'id-chart-settings-dlg-hor';
// Disable Axises
var
disableEditAxis
=
(
chartType
==
Asc
.
c_oAscChartTypeSettings
.
pie
||
chartType
==
Asc
.
c_oAscChartTypeSettings
.
doughnut
||
chartType
==
Asc
.
c_oAscChartTypeSettings
.
pie3d
);
$
(
'
#chart-vaxis, #chart-haxis
'
).
toggleClass
(
'
disabled
'
,
disableEditAxis
);
var
disableAxisPos
=
(
chartType
==
Asc
.
c_oAscChartTypeSettings
.
barNormal3d
||
chartType
==
Asc
.
c_oAscChartTypeSettings
.
barStacked3d
||
chartType
==
Asc
.
c_oAscChartTypeSettings
.
barStackedPer3d
||
chartType
==
Asc
.
c_oAscChartTypeSettings
.
hBarNormal3d
||
chartType
==
Asc
.
c_oAscChartTypeSettings
.
hBarStacked3d
||
chartType
==
Asc
.
c_oAscChartTypeSettings
.
hBarStackedPer3d
||
chartType
==
Asc
.
c_oAscChartTypeSettings
.
barNormal3dPerspective
);
$
(
'
#horizontal-axis-position
'
).
toggleClass
(
'
disabled
'
,
disableAxisPos
);
// Reverse Axises
var
needReverse
=
(
...
...
@@ -879,19 +1007,19 @@ define([
}
},
_getHorAxisProp
:
function
()
{
_getHor
izontal
AxisProp
:
function
()
{
var
chartObject
=
this
.
api
.
asc_getChartObject
(),
verHorProps
=
chartObject
.
getHorAxisProps
();
return
(
verHorProps
.
getAxisType
()
==
Asc
.
c_oAscAxisType
.
val
)
?
verHorProps
:
chartObject
.
getVertAxisProps
()
;
return
(
verHorProps
.
getAxisType
()
==
Asc
.
c_oAscAxisType
.
val
)
?
chartObject
.
getVertAxisProps
()
:
verHorProps
;
},
_setHorAxisProp
:
function
(
axisProps
)
{
_setHor
izontal
AxisProp
:
function
(
axisProps
)
{
var
chartObject
=
this
.
api
.
asc_getChartObject
(),
verAxisProps
=
chartObject
.
getHorAxisProps
();
if
(
!
_
.
isUndefined
(
chartObject
))
{
chartObject
[(
verAxisProps
.
getAxisType
()
==
Asc
.
c_oAscAxisType
.
val
)
?
'
put
HorAxisProps
'
:
'
putVert
AxisProps
'
](
axisProps
);
chartObject
[(
verAxisProps
.
getAxisType
()
==
Asc
.
c_oAscAxisType
.
val
)
?
'
put
VertAxisProps
'
:
'
putHor
AxisProps
'
](
axisProps
);
this
.
api
.
asc_editChartDrawingObject
(
chartObject
);
}
},
...
...
apps/spreadsheeteditor/mobile/app/template/EditChart.template
View file @
0a98532b
...
...
@@ -370,14 +370,13 @@
<div class="navbar">
<div class="navbar-inner">
<div class="left sliding"><a href="#" class="back link"> <i class="icon icon-back"></i><% if (!android) { %><span><%= scope.textBack %></span><% } %></a></div>
<div class="center sliding"
id="edit-chart-vertical-axis-title">Vertical Axi
s</div>
<div class="center sliding"
>Axis Option
s</div>
<div class="right"><% if (phone) { %><a href="#" class="link icon-only close-picker"><i class="icon icon-expand-down"></i></a><% } %></div>
</div>
</div>
<div class="pages">
<div class="page" data-page="edit-chart-vertical-axis">
<div class="page-content">
<div class="content-block-title">Axis Options</div>
<div class="list-block">
<ul>
<li id="edit-vertical-axis-min-val">
...
...
@@ -515,16 +514,111 @@
<div class="navbar">
<div class="navbar-inner">
<div class="left sliding"><a href="#" class="back link"> <i class="icon icon-back"></i><% if (!android) { %><span><%= scope.textBack %></span><% } %></a></div>
<div class="center sliding"
id="edit-chart-horizontal-axis-title">Horizontal Axi
s</div>
<div class="center sliding"
>Axis Option
s</div>
<div class="right"><% if (phone) { %><a href="#" class="link icon-only close-picker"><i class="icon icon-expand-down"></i></a><% } %></div>
</div>
</div>
<div class="pages">
<div class="page" data-page="edit-chart-horizontal-axis">
<div class="page-content">
<div class="content-block-title">Axis Options</div>
<div class="list-block">
<ul>
<li>
<a id="horizontal-axis-cross" class="item-link smart-select" data-back-on-select="true">
<select name="horizontal-axis-cross"></select>
<div class="item-content">
<div class="item-inner">
<div class="item-title">Axis Crosses</div>
<div class="item-after">None</div>
</div>
</div>
</a>
</li>
<li id="edit-horizontal-axis-cross-value" style="display: none;">
<div class="item-content">
<div class="item-inner">
<div class="item-title">Crosses Value</div>
<div class="item-after">
<div class="item-input">
<input class="field right" type="number" placeholder="0">
</div>
</div>
</div>
</div>
</li>
</ul>
</div>
<div class="list-block">
<ul>
<li>
<a id="horizontal-axis-position" class="item-link smart-select" data-back-on-select="true">
<select name="horizontal-axis-position">
</select>
<div class="item-content">
<div class="item-inner">
<div class="item-title">Axis Position</div>
<div class="item-after">None</div>
</div>
</div>
</a>
</li>
<li id="horizontal-axis-in-reverse">
<div class="item-content">
<div class="item-inner">
<div class="item-title">Values in Reverse Order</div>
<div class="item-after">
<label class="label-switch">
<input type="checkbox">
<div class="checkbox"></div>
</label>
</div>
</div>
</div>
</li>
</ul>
</div>
<div class="content-block-title">Tick Options</div>
<div class="list-block">
<ul>
<li>
<a id="horizontal-axis-tick-major" class="item-link smart-select" data-back-on-select="true">
<select name="horizontal-axis-tick-major"></select>
<div class="item-content">
<div class="item-inner">
<div class="item-title">Major Type</div>
<div class="item-after">None</div>
</div>
</div>
</a>
</li>
<li>
<a id="horizontal-axis-tick-minor" class="item-link smart-select" data-back-on-select="true">
<select name="horizontal-axis-tick-minor"></select>
<div class="item-content">
<div class="item-inner">
<div class="item-title">Minor Type</div>
<div class="item-after">None</div>
</div>
</div>
</a>
</li>
</ul>
</div>
<div class="content-block-title">Label Options</div>
<div class="list-block">
<ul>
<li>
<a id="horizontal-axis-label-pos" class="item-link smart-select" data-back-on-select="true">
<select name="horizontal-axis-label-pos"></select>
<div class="item-content">
<div class="item-inner">
<div class="item-title">Label Position</div>
<div class="item-after">None</div>
</div>
</div>
</a>
</li>
</ul>
</div>
</div>
</div>
...
...
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