Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
X
xblock-drag-and-drop-v2
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
OpenEdx
xblock-drag-and-drop-v2
Commits
a27f413b
Commit
a27f413b
authored
Jan 25, 2016
by
Jonathan Piacenti
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Make sure droppable zones have unique IDs.
parent
2c0b51ef
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
12 additions
and
5 deletions
+12
-5
drag_and_drop_v2/drag_and_drop_v2.py
+2
-0
drag_and_drop_v2/public/js/drag_and_drop.js
+1
-0
tests/integration/test_render.py
+5
-5
tests/unit/data/html/config_out.json
+1
-0
tests/unit/data/old/config_out.json
+1
-0
tests/unit/data/plain/config_out.json
+1
-0
tests/unit/test_basics.py
+1
-0
No files found.
drag_and_drop_v2/drag_and_drop_v2.py
View file @
a27f413b
...
@@ -156,6 +156,8 @@ class DragAndDropBlock(XBlock, XBlockWithSettingsMixin, ThemableXBlockMixin):
...
@@ -156,6 +156,8 @@ class DragAndDropBlock(XBlock, XBlockWithSettingsMixin, ThemableXBlockMixin):
return
{
return
{
"zones"
:
self
.
data
.
get
(
'zones'
,
[]),
"zones"
:
self
.
data
.
get
(
'zones'
,
[]),
# SDK doesn't supply url_name.
"url_name"
:
getattr
(
object
,
'url_name'
,
''
),
"display_zone_labels"
:
self
.
data
.
get
(
'displayLabels'
,
False
),
"display_zone_labels"
:
self
.
data
.
get
(
'displayLabels'
,
False
),
"display_zone_borders"
:
self
.
data
.
get
(
'displayBorders'
,
False
),
"display_zone_borders"
:
self
.
data
.
get
(
'displayBorders'
,
False
),
"items"
:
items_without_answers
(),
"items"
:
items_without_answers
(),
...
...
drag_and_drop_v2/public/js/drag_and_drop.js
View file @
a27f413b
...
@@ -171,6 +171,7 @@ function DragAndDropBlock(runtime, element, configuration) {
...
@@ -171,6 +171,7 @@ function DragAndDropBlock(runtime, element, configuration) {
delete
zone
.
width
;
delete
zone
.
width
;
zone
.
height_percent
=
(
+
zone
.
height
)
/
bg_image_height
*
100
;
zone
.
height_percent
=
(
+
zone
.
height
)
/
bg_image_height
*
100
;
delete
zone
.
height
;
delete
zone
.
height
;
zone
.
id
=
configuration
.
url_name
+
'-'
+
zone
.
id
;
}
}
};
};
...
...
tests/integration/test_render.py
View file @
a27f413b
...
@@ -191,12 +191,12 @@ class TestDragAndDropRender(BaseIntegrationTest):
...
@@ -191,12 +191,12 @@ class TestDragAndDropRender(BaseIntegrationTest):
self
.
assertIn
(
'ui-droppable'
,
self
.
get_element_classes
(
zone
))
self
.
assertIn
(
'ui-droppable'
,
self
.
get_element_classes
(
zone
))
zone_box_percentages
=
box_percentages
[
index
]
zone_box_percentages
=
box_percentages
[
index
]
self
.
_assert_box_percentages
(
# pylint: disable=star-args
self
.
_assert_box_percentages
(
# pylint: disable=star-args
'#zone-{}'
.
format
(
zone_number
),
**
zone_box_percentages
'#
-
zone-{}'
.
format
(
zone_number
),
**
zone_box_percentages
)
)
zone_name
=
zone
.
find_element_by_css_selector
(
'p.zone-name'
)
zone_name
=
zone
.
find_element_by_css_selector
(
'p.zone-name'
)
self
.
assertEqual
(
zone_name
.
text
,
'Z
ONE
{}'
.
format
(
zone_number
))
self
.
assertEqual
(
zone_name
.
text
,
'Z
one
{}'
.
format
(
zone_number
))
zone_description
=
zone
.
find_element_by_css_selector
(
'p.zone-description'
)
zone_description
=
zone
.
find_element_by_css_selector
(
'p.zone-description'
)
self
.
assertEqual
(
zone_description
.
text
,
'T
HIS DESCRIBES ZONE
{}'
.
format
(
zone_number
))
self
.
assertEqual
(
zone_description
.
text
,
'T
his describes zone
{}'
.
format
(
zone_number
))
# Zone description should only be visible to screen readers:
# Zone description should only be visible to screen readers:
self
.
assertEqual
(
zone_description
.
get_attribute
(
'class'
),
'zone-description sr'
)
self
.
assertEqual
(
zone_description
.
get_attribute
(
'class'
),
'zone-description sr'
)
...
@@ -245,7 +245,7 @@ class TestDragAndDropRender(BaseIntegrationTest):
...
@@ -245,7 +245,7 @@ class TestDragAndDropRender(BaseIntegrationTest):
self
.
load_scenario
()
self
.
load_scenario
()
zones
=
self
.
_get_zones
()
zones
=
self
.
_get_zones
()
for
index
,
dummy
in
enumerate
(
zones
,
start
=
1
):
for
index
,
dummy
in
enumerate
(
zones
,
start
=
1
):
zone
=
'#zone-{}'
.
format
(
index
)
zone
=
'#
-
zone-{}'
.
format
(
index
)
for
side
in
self
.
SIDES
:
for
side
in
self
.
SIDES
:
self
.
assertEqual
(
self
.
_get_style
(
zone
,
'border{}Width'
.
format
(
side
),
True
),
'0px'
)
self
.
assertEqual
(
self
.
_get_style
(
zone
,
'border{}Width'
.
format
(
side
),
True
),
'0px'
)
self
.
assertEqual
(
self
.
_get_style
(
zone
,
'border{}Style'
.
format
(
side
),
True
),
'none'
)
self
.
assertEqual
(
self
.
_get_style
(
zone
,
'border{}Style'
.
format
(
side
),
True
),
'none'
)
...
@@ -254,7 +254,7 @@ class TestDragAndDropRender(BaseIntegrationTest):
...
@@ -254,7 +254,7 @@ class TestDragAndDropRender(BaseIntegrationTest):
self
.
load_scenario
(
zone_borders
=
True
)
self
.
load_scenario
(
zone_borders
=
True
)
zones
=
self
.
_get_zones
()
zones
=
self
.
_get_zones
()
for
index
,
dummy
in
enumerate
(
zones
,
start
=
1
):
for
index
,
dummy
in
enumerate
(
zones
,
start
=
1
):
zone
=
'#zone-{}'
.
format
(
index
)
zone
=
'#
-
zone-{}'
.
format
(
index
)
for
side
in
self
.
SIDES
:
for
side
in
self
.
SIDES
:
self
.
assertEqual
(
self
.
_get_style
(
zone
,
'border{}Width'
.
format
(
side
),
True
),
'1px'
)
self
.
assertEqual
(
self
.
_get_style
(
zone
,
'border{}Width'
.
format
(
side
),
True
),
'1px'
)
self
.
assertEqual
(
self
.
_get_style
(
zone
,
'border{}Style'
.
format
(
side
),
True
),
'dotted'
)
self
.
assertEqual
(
self
.
_get_style
(
zone
,
'border{}Style'
.
format
(
side
),
True
),
'dotted'
)
...
...
tests/unit/data/html/config_out.json
View file @
a27f413b
...
@@ -10,6 +10,7 @@
...
@@ -10,6 +10,7 @@
"initial_feedback"
:
"HTML <strong>Intro</strong> Feed"
,
"initial_feedback"
:
"HTML <strong>Intro</strong> Feed"
,
"display_zone_borders"
:
false
,
"display_zone_borders"
:
false
,
"display_zone_labels"
:
false
,
"display_zone_labels"
:
false
,
"url_name"
:
""
,
"zones"
:
[
"zones"
:
[
{
{
...
...
tests/unit/data/old/config_out.json
View file @
a27f413b
...
@@ -10,6 +10,7 @@
...
@@ -10,6 +10,7 @@
"initial_feedback"
:
"Intro Feed"
,
"initial_feedback"
:
"Intro Feed"
,
"display_zone_borders"
:
false
,
"display_zone_borders"
:
false
,
"display_zone_labels"
:
false
,
"display_zone_labels"
:
false
,
"url_name"
:
""
,
"zones"
:
[
"zones"
:
[
{
{
...
...
tests/unit/data/plain/config_out.json
View file @
a27f413b
...
@@ -10,6 +10,7 @@
...
@@ -10,6 +10,7 @@
"initial_feedback"
:
"This is the initial feedback."
,
"initial_feedback"
:
"This is the initial feedback."
,
"display_zone_borders"
:
false
,
"display_zone_borders"
:
false
,
"display_zone_labels"
:
false
,
"display_zone_labels"
:
false
,
"url_name"
:
""
,
"zones"
:
[
"zones"
:
[
{
{
...
...
tests/unit/test_basics.py
View file @
a27f413b
...
@@ -40,6 +40,7 @@ class BasicTests(TestCaseMixin, unittest.TestCase):
...
@@ -40,6 +40,7 @@ class BasicTests(TestCaseMixin, unittest.TestCase):
"item_background_color"
:
None
,
"item_background_color"
:
None
,
"item_text_color"
:
None
,
"item_text_color"
:
None
,
"initial_feedback"
:
START_FEEDBACK
,
"initial_feedback"
:
START_FEEDBACK
,
"url_name"
:
""
,
})
})
self
.
assertEqual
(
zones
,
DEFAULT_DATA
[
"zones"
])
self
.
assertEqual
(
zones
,
DEFAULT_DATA
[
"zones"
])
# Items should contain no answer data:
# Items should contain no answer data:
...
...
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