How to click a dropdown arrow in extJS using Python and Selenium? - html

The full HTML code for the table is as follows:
<table id="clearablecombo-1497" class="x-field clearableCombo x-form-item x-field-default x-anchor-form-item" cellpadding="0" style="table-layout: fixed; width: 287px;">
<tbody>
<tr id="clearablecombo-1497-inputRow">
<td id="clearablecombo-1497-labelCell" class="x-field-label-cell" width="105" valign="top" halign="right" style="">
<label id="clearablecombo-1497-labelEl" class="x-form-item-label x-form-item-label-right" style="width:100px;margin-right:5px;" for="clearablecombo-1497-inputEl">Document Status:</label>
</td>
<td id="clearablecombo-1497-bodyEl" class="x-form-item-body x-form-trigger-wrap-focus" colspan="2" role="presentation" style="width: 100%;">
<table id="clearablecombo-1497-triggerWrap" class="x-form-trigger-wrap" cellspacing="0" cellpadding="0" style="width: 100%; table-layout: fixed;">
<tbody>
<tr>
<td id="clearablecombo-1497-inputCell" class="x-form-trigger-input-cell" style="width: 100%;">
<div id="ext-gen1890" class="x-hide-display x-form-data-hidden" role="presentation"/>
<input id="clearablecombo-1497-inputEl" class="x-form-field x-form-text x-form-focus x-field-form-focus x-field-default-form-focus" type="text" style="width: 100%; text-transform: uppercase; -moz-user-select: text;" name="documentStatus" autocomplete="off" aria-invalid="false"/>
</td>
<td id="ext-gen1888" class="x-trigger-cell" valign="top" style="width:26px">
<div id="ext-gen1886" class="x-trigger-index-0 x-form-trigger x-form-arrow-trigger x-unselectable x-form-trigger-over x-form-arrow-trigger-over" role="button" style="-moz-user-select: none;"/>
</td>
<td id="ext-gen1889" class="x-trigger-cell" valign="top" style="width:26px">
<div id="ext-gen1887" class="x-trigger-index-1 x-form-trigger x-form-clear-trigger x-form-trigger-last x-unselectable" role="button" style="-moz-user-select: none;"/>
</td>
</tr>
</tbody>
</table>
</td>
<td id="clearablecombo-1497-errorEl" class="x-form-error-msg x-external-error-icon x-form-invalid-icon" width="0" style="display:none" data-errorqtip=""/>
</tr>
</tbody>
</table>
The part of the HTML I'm attempting to manipulate is this part specifically:
<div id="ext-gen1886" class="x-trigger-index-0 x-form-trigger x-form-arrow-trigger x-unselectable x-form-trigger-over x-form-arrow-trigger-over" role="button" style="-moz-user-select: none;"/>
The above part is the actual dropdown arrow which is also in the above large portion of the HTML. The drop down text I need to select is "Rejected". The HTML with the selection options are as follows:
<div id="boundlist-1558" class="x-boundlist x-boundlist-floating x-layer x-boundlist-default" tabindex="-1" style="left: 136px; top: 346px; height: auto; z-index: 19001; width: 182px;">
<div id="boundlist-1558-listEl" class="x-boundlist-list-ct" style="overflow: auto; height: auto;">
<ul>
<li class="x-boundlist-item x-boundlist-item-over" role="option">All</li>
<li class="x-boundlist-item" role="option">Waiting QA</li>
<li class="x-boundlist-item" role="option">AutoTec Approved</li>
<li class="x-boundlist-item" role="option">User Approved</li>
<li class="x-boundlist-item" role="option">Rejected</li>
<li class="x-boundlist-item" role="option">Deleted</li>
</ul>
</div>
</div>
Anyone have any suggestions of the XPath I would use to do this? I tried just inputting the text like a textbox, however there are certain boxes such as the Country and State that have to be selected to enable each other.

I think 'role' is the best attr in this case to find the elements:
--this one select your desired element
"//div[contains(id, 'ext-gen')][#role='button'][contains(#class, 'x-form-trigger-over')]"
--this one select your desired option
"//li[#role='option'][text()='Rejected']"

As I understand these are the target elements:
xpath = '//div[contains(id, "ext-gen")][#class="x-trigger-index-0 x-form-trigger x-form-arrow-trigger x-unselectable x-form-trigger-over x-form-arrow-trigger-over"]'
drop_down = self.driver.find_element_by_xpath(xpath)
drop_down.click()
xpath = '//li[#class="x-boundlist-item"][contains(text(), "Rejected")]'
option = self.driver.find_element_by_xpath(xpath)
option.click()

Related

How to get particular labels and entities from HTML content as concatenated string?

<div id="formContents" class="dformDisplay "><div class="sectionDiv expanded">
<div class="Title expanded ToggleSection shead" id="sect_s1Header" style="margin-top:1em">
<span class="sectionTitle">Issue details:</span></div>
<hr/>
<div><!--The div around the table is so that the toggling can be animated smoothly-->
<table class="formSection LabelsAbove" id="sect_s1">
<tr class="formRow">
<td class="label lc" id="tdl_8">
<label class="fieldLabel"><b>Address</b></label>
<table border="0" cellpadding="0" cellspacing="0" class="EmailFieldPadder" style="width:98%;margin-top:.3em;margin-right:1.5em;" valign="top">
<tr><td class="EmailDivWrapper" style="background-color:#f5f5f5;padding: 0.83em;border-radius:3px;margin:0;border:0px;">
<div class="cell cc" id="tdf_8">
<a href="https://maps.google.com/?q=1183+Pelham+Wood+Dr%2C+Rock+Hill%2C+SC+29732">1183
Pelham Wood Dr, Rock Hill, SC 29732</a>
</div>
</td></tr></table>
</td>
<td class="label lc" colspan="100" id="tdl_9">
<label class="fieldLabel"><b>Dispatch Region</b></label>
<table border="0" cellpadding="0" cellspacing="0" class="EmailFieldPadder" style="width:98%;margin-top:.3em;margin-right:1.5em;" valign="top">
<tr><td class="EmailDivWrapper" style="background-color:#f5f5f5;padding: 0.83em;border-radius:3px;margin:0;border:0px;">
<div class="cell cc nowrap" id="tdf_9">5</div>
</td></tr></table>
</td>
</tr>
<tr class="formRow">
<td class="label lc" id="tdl_10">
<label class="fieldLabel"><b>Market:</b></label>
<table border="0" cellpadding="0" cellspacing="0" class="EmailFieldPadder" style="width:98%;margin-top:.3em;margin-right:1.5em;" valign="top">
<tr><td class="EmailDivWrapper" style="background-color:#f5f5f5;padding: 0.83em;border-radius:3px;margin:0;border:0px;">
<div class="cell cc" id="tdf_10">Charlotte</div>
</td></tr></table>
</td>
<div class="sectionDiv expanded">
<div class="Title expanded ToggleSection shead"
style="margin-top:1em"
id="sect_s19Header">
<span class="sectionTitle">Tenant Preferred Scheduled Date/Time</span></div>
<hr />
<div><!--The div around the table is so that the toggling can be animated smoothly-->
<table id="sect_s19" class="formSection LabelsLeft">
<tr class="formRow ">
<td id="tdl_52" class="label lc"
style="vertical-align:top; border:0 solid white; border-bottom-width: .83em; padding: 0.83em 0; border-right-width: .83em;"
><label class="fieldLabel" ><b>Preference 1: </b></label></td>
<td id="tdf_52" class="cell cc nowrap"
style="background-color:#f5f5f5; border: solid white; border-top-width:0;border-right-width: 5.455em; border-left-width:.909em; vertical-align:top; border-bottom-width: .909em; padding: .83em;"
>Friday, 02-03</td>
from bs4 import BeautifulSoup
soup = BeautifulSoup(html_content, 'html.parser')
section_sel = 'div#formContents div.sectionDiv.expanded'
label_sel = 'label.fieldLabel'
for datas in soup.select(f'{section_sel}:has({label_sel}+table td)'):
labels = datas.select(f'{label_sel}:has(+table td)')
labels = [' '.join(l.get_text(' ').split()) for l in labels]
entity_data = [' '.join([' '.join(td.get_text(' ').split()) for td in ed.select('td')]) for ed in datas.select(f'{label_sel}+table:has(td)')]
for l, ed in zip(labels, entity_data): print(f'{l}: {ed}')
Required output: Address: 1183 Pelham Wood Dr, Rock Hill, SC 29732 ; Dispatch Region: 5 ; Market: Charlotte ; Preference 1: Friday, 02-03
I am unable to get the Preference 1 with the solution. I am getting all other label. Since there is no table tag below label tag its not getting. Kindly help with solution to get all labels from the html content
Not sure what is wrong with this solution and use dict to create a CSV, what I assume you like to prepare with the string construct.
However, use the approache and this way:
';'.join(
[
f"{e.text.strip(': ')}:{' '.join(e.find_next('td').text.split())}"
for e in soup.select('div#formContents label')
]
)
What results into:
'Address:1183 Pelham Wood Dr, Rock Hill, SC 29732;Dispatch Region:5;Market:Charlotte;Preference 1:Friday, 02-03'

Is the tabbing sequence logical?in HTML

Hi I am facing a very hard issue regarding tab order for accessibility.My tabs are functioned through jquery.ui.min.js. Tab order,classes & function are coming from there.Although all tabs are functioning properly but when i validate i am getting accessibility issue.Please suggest me other way.
I am looking for accessibility point of view only.One more thing this library adding blank style (style="") on every element.How can i remove it Please suggest.
<div class="tabs ui-tabs ui-widget ui-widget-content ui-corner-all" style="padding: 10px;">
<ul class="ui-tabs-nav ui-helper-reset ui-helper-clearfix ui-widget-header ui-corner-all" style="">
<li tabindex="0" class="ui-state-default ui-corner-top ui-tabs-active ui-state-active" aria-controls="tab-content4" aria-selected="true" style="z-index: 2147483646;">tab1</li>
<li tabindex="-1" class="ui-state-default ui-corner-top" aria-controls="tab-content1" aria-selected="false" style="">tab2</li>
<li tabindex="-1" class="ui-state-default ui-corner-top" aria-controls="tab-content2" aria-selected="false" style="">tab3</li>
<li tabindex="-1" class="ui-state-default ui-corner-top" aria-controls="tab-content3" aria-selected="false" style="">tab4</li>
<!-- <li>Others</li> -->
</ul>
<strong style=""> <a class="fl_r" href="#" style="">Subscribe
</a></strong>
<div id="tab-content4" class="tab-content ui-tabs-panel ui-widget-content ui-corner-bottom" aria-expanded="true" aria-hidden="false" style="">
<table class="ui-table" style="border-collapse: collapse;">
<tbody style="">
<tr style="">
<td>test1</td>
</tr>
<tr style="">
<td>test2</td>
</tr>
<tr style="">
<td>test3</td>
</tr>
</tbody>
</table>
</div>
<div id="tab-content1" class="tab-content ui-tabs-panel ui-widget-content ui-corner-bottom" aria-expanded="false" aria-hidden="true" style="display: none;">
<table class="ui-table" style="border-collapse: collapse;">
<tbody style="">
<tr style="">
<td>test2</td>
</tr>
<tr style="">
<td>test21</td>
</tr>
<tr style="">
<td>test22</td>
</tr>
</tbody>
</table>
</div>
<div id="tab-content2" class="tab-content ui-tabs-panel ui-widget-content ui-corner-bottom" aria-expanded="false" aria-hidden="true" style="display: none;">
<table class="ui-table" style="border-collapse: collapse;">
<tbody style="">
<tr style="">
<td>test3</td>
</tr>
<tr style="">
<td>test31</td>
</tr>
<tr style="">
<td>test32</td>
</tr>
</tbody>
</table>
</div>
<div id="tab-content3" class="tab-content ui-tabs-panel ui-widget-content ui-corner-bottom" aria-expanded="false" aria-hidden="true" style="display: none;">
<table class="ui-table" style="border-collapse: collapse;">
<tbody style="">
<tr style="">
<td>test4</td>
</tr>
<tr style="">
<td>test41</td>
</tr>
<tr style="">
<td>test42</td>
</tr>
</tbody>
</table>
</div>
<!-- <div id="tab-content4" class="tab-content">&nbsp;</div> -->
</div>
When running the siteimprove plugin, you will get a "review" item (not an "error" or "warning") for any element that has a tabindex specified. Or at least that's what my testing is showing.
It doesn't seem to matter if valid tabindex values of 0 or -1 are used. I would expect a "review" or "warning" if tabindex were greater than 0 since that's highly discouraged in the html spec.
Warning!Using a positive value for tabindex to specify the element’s position in the sequential focus navigation order interacts with the order of all focusable elements. It is error-prone, and therefore not recommended. Authors should generally leave elements to appear in their default order.
So siteimprove is being a bit overzealous and flagging every use of tabindex as a review candidate.
Note that in your example, the tabindex="0" on all the <a> elements is not necessary (*). They are already in the tab sequence.
(*) If an anchor (<a>) does not have an href attribute, then the anchor is not a tabstop and would need a tabindex="0" if you wanted focus to move to the element. However, the anchor would also need a keyboard and mouse event handler to handle clicks since an anchor without an href does not handle any events.
The code sample is also a little weird in that the list item (<li>) has a tabindex="0" and the nested link in that list item allows focus. That's two tab stops for essentially the same element. That would be an accessibility issue.

Prevent scroll when children select clicked

Have structure like this
<div style="overflow-x:auto; overflow-y: hidden; width: 100%; white-space: nowrap;">
<table>
<tbody>
<tr>
<td>
<select>
*some options*
</select>
</td>
</tr>
</tbody>
</table>
</div>
And when i clicked select first time scroll resets to leftmost position. When i clicked it 2nd time it stays at the current position. This selects created by Chosen library and for real looks like
<div class="chzn-container chzn-container-single chzn-container-single-nosearch" style="width: 215px;" title="">
<a class="chzn-single" tabindex="-1">
<span>selected option</span>
</a>
<div class="chzn-drop"><div class="chzn-search">
<input type="text" autocomplete="off" readonly="">
</div>
<ul class="chzn-results">
<li class="active-result result-selected" style="" data-option-array-index="0">Option2</li>
<li class="active-result" style="" data-option-array-index="1">Option3</li>
<li class="active-result" style="" data-option-array-index="2">Option4</li>
</ul>
</div>
</div>
Trouble was in .focus method on Chosen library. Close to dropdown method. Just comment this and it stop reseting scroll

ExtJs HTML/DOM code optimization

Spent already a lot of resources to figure out how to optimize extJs HTML code.
I have simple combobox with a label and extjs throw on a page this:
<tr role="presentation" id="inputs[1].TypeId-inputRow" class="x-form-item-input-row">
<td role="presentation" id="inputs[1].TypeId-labelCell" style="" valign="top" halign="left" width="88" class="x-field-label-cell">
<label
id="inputs[1].TypeId-labelEl"
for="inputs[1].TypeId-inputEl"
class="x-form-item-label x-unselectable x-form-item-label-left"
style="width:83px;margin-right:5px;" unselectable="on">
Placement ID:
</label>
</td>
<td role="presentation" class="x-form-item-body x-form-trigger-wrap-focus" id="inputs[1].TypeId-bodyEl" colspan="2">
<table id="inputs[1].TypeId-triggerWrap" class="x-form-trigger-wrap" cellpadding="0" cellspacing="0" style="table-layout: auto;">
<tbody>
<tr>
<td id="inputs[1].TypeId-inputCell" class="x-form-trigger-input-cell">
<div class="x-hide-display x-form-data-hidden" role="presentation" id="ext-gen1311">
</div>
<input
id="inputs[1].TypeId-inputEl"
type="text"
class="x-form-field x-form-required-field x-form-text x-trigger-noedit x-form-focus x-field-form-focus x-field-default-form-focus"
autocomplete="off"
name="inputs[1].TypeId"
placeholder="DATA SOURCE"
readonly="readonly"
aria-invalid="false"
data-errorqtip=""
style="width: 137px;">
</td>
<td valign="top" class=" x-trigger-cell x-unselectable" style="width:22px;" id="ext-gen1310">
<div class="x-trigger-index-0 x-form-trigger x-form-arrow-trigger x-form-trigger-first" role="button" id="ext-gen1309">
</div>
</td>
</tr>
</tbody>
</table>
</td>
</tr>
How could I change tables inside a tables just for simple xtype: 'combobox'?
I have hundreds like that on a page, it slows down a lot because very heavy HTML code.
it could be done with simple div wit ha float on it, why does extJS renders all this table code?
If you want/need a simpler markup in Ext, the only way is to code your own component where you can define a simpler one.
There is no way of simplifying the Ext generated markup without a danger of breaking functionality or layout engine.

How to make drop-down menu appear over a combobox in IE6?

I'm facing a problem in IE6 :
My website contains a drop-down menu and some pages contains comboboxes.
When I roll-out a menu and it's covering a combobox, the combobox always appears over the menu !
My website is to be used exclusively on IE6, so I want to solve this problem on IE6 and make the drop-down menu apprear OVER the combobox in such situations.
Here is a code snippet that illustrates the problem :
<html>
<body>
<!-- Menu -->
<table width="20%" border="0" style="position:relative; z-index:100;">
<tr>
<td colspan="0">
<table style="background-color: #40668C; color: white; z-index:100;" width="100%">
<tr>
<td>Agenda</td>
</tr>
<tr>
<td>
<table
align="right"
valign="top"
width="100%"
height="100%"
style=" visibility: visible;
position: absolute;
background-color: #40668C;
color: white;
top: 21px;
z-index:100;">
<tr><td>Personnal</td></tr>
<tr><td>Group</td></tr>
<tr><td>Day</td></tr>
</table>
</td>
</tr>
</table>
</td>
</tr>
</table>
<!-- Combobox -->
<form style="z-index: 0;">
<TABLE style="z-index: 0;">
<TR style="z-index: 0;">
<TD style="z-index: 0;">
<TABLE style="z-index: 0;">
<TR style="z-index: 0;">
<TD>Combobox :</TD>
<TD style="z-index: 0;">
<SELECT style="z-index: 0;">
<OPTION></option>
<OPTION>Element 1</option>
<OPTION>Element 2</option>
</select>
</TD>
</TR>
</TABLE>
</TD>
</TR>
</TABLE>
</form>
</body>
</html>
I know this problem has already been reported and it's because of IE6 but unfortunately, I tried different solutions so far without any success.
Thanks in advance !
This is the result of a z-index bug in IE6. Select elements are given a high z-index, so they always appear in front of other elements.
A quick way to fix this is to hide the select when your menu is open. You can call a function like this when you open the menu:
function hide_select(myelement){
var select = document.getElementById('myelement');
if(select.style.visibility == "hidden")
{
select.style.visibility="visible"
}else{
select.style.visibility="hidden";
}
}
Reference: http://www.tinyqueen.com/web-site-design/ie6-select-z-index-bug-a-workaround
It's an IE6 bug.
There is no way around it other than setting the combo-box's CSS attribute display: none; while hovering on the dropdown, and setting it visible again otherwise.