Changeset 195685 in webkit


Ignore:
Timestamp:
Jan 27, 2016 12:24:37 PM (8 years ago)
Author:
commit-queue@webkit.org
Message:

Need ability to specify alternate image for AutoFill button in input fields.
https://bugs.webkit.org/show_bug.cgi?id=153116.
rdar://problem/23384854.

Patch by Zhuo Li <zachli@apple.com> on 2016-01-27
Reviewed by Darin Adler.

Source/WebCore:

Add a new AutoFill button that can be shown in <input> elements.

Tests: fast/forms/auto-fill-button/input-contacts-auto-fill-button.html

fast/forms/auto-fill-button/show-correct-auto-fill-button-when-auto-fill-button-type-changes.html

  • css/html.css:

(input::-webkit-contacts-auto-fill-button):
(input::-webkit-contacts-auto-fill-button:hover):
(input::-webkit-contacts-auto-fill-button:active):
Add default style rules for the Contacts AutoFill button based on the ones used for
Manual AutoFill button.

  • html/HTMLInputElement.cpp:

(WebCore::HTMLInputElement::setShowAutoFillButton):

  • html/HTMLInputElement.h:

(WebCore::HTMLInputElement::autoFillButtonType):

  • Replace the boolean parameter with a new parameter to specify the type of the AutoFill button.
  • Declare a private variable to keep a record of the type of the current AutoFill

button.
(WebCore::HTMLInputElement::showAutoFillButton): Deleted.

  • html/HTMLTextFormControlElement.h:

Declare enum for AutoFill button type.

  • html/TextFieldInputType.cpp:

(WebCore::autoFillButtonTypeToAutoFillButtonPseudoClassName):
(WebCore::isAutoFillButtonTypeChanged):
(WebCore::TextFieldInputType::shouldDrawAutoFillButton): None means the AutoFill button is not
enabled.
(WebCore::TextFieldInputType::createAutoFillButton): Only create the AutoFill button
if the type is expected.
(WebCore::TextFieldInputType::updateAutoFillButton):
Handle the case where AutoFill button type changes in the text field.

  • html/TextFieldInputType.h:
  • testing/Internals.cpp:

(WebCore::stringToAutoFillButtonType): Convert the string to AutoFill button type.
(WebCore::Internals::setShowAutoFillButton): Add a new parameter to specify the type of the AutoFill button.

  • testing/Internals.h: Ditto.
  • testing/Internals.idl: Ditto.

Source/WebKit2:

  • WebProcess/InjectedBundle/API/c/WKBundleNodeHandle.cpp:

(toAutoFillButtonType): Convert the WebKit AutoFill button type enum to WebCore AutoFill button
type enum.
(WKBundleNodeHandleSetHTMLInputElementAutoFillButtonEnabledWithButtonType): Added to be able to specify
what the AutoFill button type is. None means the AutoFill button is not shown.
(WKBundleNodeHandleSetHTMLInputElementAutoFillButtonEnabled): Deprecate this method.

  • WebProcess/InjectedBundle/API/c/WKBundleNodeHandlePrivate.h: Declare an AutoFill button type enum.
  • WebProcess/InjectedBundle/DOM/InjectedBundleNodeHandle.cpp:

(WebKit::InjectedBundleNodeHandle::isHTMLInputElementAutoFillButtonEnabled): None means the AutoFill button is not enabled.
(WebKit::InjectedBundleNodeHandle::setHTMLInputElementAutoFillButtonEnabledWithButtonType): Use the new parameter to specify
what the AutoFill button type is.

  • WebProcess/InjectedBundle/DOM/InjectedBundleNodeHandle.h: Ditto.

LayoutTests:

  • fast/forms/auto-fill-button/hide-auto-fill-button-when-input-becomes-disabled.html: The test API has

another parameter to specify what type the AutoFill button is.

  • fast/forms/auto-fill-button/hide-auto-fill-button-when-input-becomes-readonly.html: Ditto.
  • fast/forms/auto-fill-button/input-contacts-auto-fill-button-expected.txt: Added.
  • fast/forms/auto-fill-button/input-contacts-auto-fill-button.html: Added.
  • fast/forms/auto-fill-button/input-auto-fill-button.html: Ditto.
  • fast/forms/auto-fill-button/input-disabled-auto-fill-button.html: Ditto.
  • fast/forms/auto-fill-button/input-readonly-non-empty-auto-fill-button.html: Ditto.
  • fast/forms/auto-fill-button/mouse-down-input-mouse-release-auto-fill-button.html: Ditto.
  • fast/forms/auto-fill-button/show-correct-auto-fill-button-when-auto-fill-button-type-changes-expected.html: Added.
  • fast/forms/auto-fill-button/show-correct-auto-fill-button-when-auto-fill-button-type-changes.html: Added.
Location:
trunk
Files:
4 added
23 edited

Legend:

Unmodified
Added
Removed
  • trunk/LayoutTests/ChangeLog

    r195682 r195685  
     12016-01-27  Zhuo Li  <zachli@apple.com>
     2
     3        Need ability to specify alternate image for AutoFill button in input fields.
     4        https://bugs.webkit.org/show_bug.cgi?id=153116.
     5        rdar://problem/23384854.
     6
     7        Reviewed by Darin Adler.
     8
     9        * fast/forms/auto-fill-button/hide-auto-fill-button-when-input-becomes-disabled.html: The test API has
     10        another parameter to specify what type the AutoFill button is.
     11        * fast/forms/auto-fill-button/hide-auto-fill-button-when-input-becomes-readonly.html: Ditto.
     12        * fast/forms/auto-fill-button/input-contacts-auto-fill-button-expected.txt: Added.
     13        * fast/forms/auto-fill-button/input-contacts-auto-fill-button.html: Added.
     14        * fast/forms/auto-fill-button/input-auto-fill-button.html: Ditto.
     15        * fast/forms/auto-fill-button/input-disabled-auto-fill-button.html: Ditto.
     16        * fast/forms/auto-fill-button/input-readonly-non-empty-auto-fill-button.html: Ditto.
     17        * fast/forms/auto-fill-button/mouse-down-input-mouse-release-auto-fill-button.html: Ditto.
     18        * fast/forms/auto-fill-button/show-correct-auto-fill-button-when-auto-fill-button-type-changes-expected.html: Added.
     19        * fast/forms/auto-fill-button/show-correct-auto-fill-button-when-auto-fill-button-type-changes.html: Added.
     20
    1212016-01-26  Ryosuke Niwa  <rniwa@webkit.org>
    222
  • trunk/LayoutTests/fast/forms/auto-fill-button/hide-auto-fill-button-when-input-becomes-disabled.html

    r185166 r195685  
    1111
    1212if (window.internals)
    13     internals.setShowAutoFillButton(password, true);
     13    internals.setShowAutoFillButton(password, "AutoFillButtonTypeCredentials");
    1414
    1515function makeFieldDisabledAndNotifyDone()
  • trunk/LayoutTests/fast/forms/auto-fill-button/hide-auto-fill-button-when-input-becomes-readonly.html

    r185166 r195685  
    1111
    1212if (window.internals)
    13     internals.setShowAutoFillButton(password, true);
     13    internals.setShowAutoFillButton(password, "AutoFillButtonTypeCredentials");
    1414
    1515function makeFieldReadOnlyAndNotifyDone()
  • trunk/LayoutTests/fast/forms/auto-fill-button/input-auto-fill-button.html

    r185166 r195685  
    11<p>This tests that the AutoFill button renders. It can only be tested in the test tool.</p>
    2 <div id='container'>
    3     <input type='text'>
    4     <input type='password'>
     2<div id="container">
     3    <input type="text">
     4    <input type="password">
    55</div>
    66<script>
     
    99    var inputs = document.querySelectorAll("input");
    1010    for (var i = 0; i < inputs.length; ++i)
    11         window.internals.setShowAutoFillButton(inputs[i], true);
     11        window.internals.setShowAutoFillButton(inputs[i], "AutoFillButtonTypeCredentials");
    1212
    1313    var dynamicInput = document.createElement("input");
    14     window.internals.setShowAutoFillButton(dynamicInput, true);
     14    window.internals.setShowAutoFillButton(dynamicInput, "AutoFillButtonTypeCredentials");
    1515    document.querySelector("#container").appendChild(dynamicInput);
    1616
    1717    var dynamicInput2 = document.createElement("input");
    18     window.internals.setShowAutoFillButton(dynamicInput2, true);
     18    window.internals.setShowAutoFillButton(dynamicInput2, "AutoFillButtonTypeCredentials");
    1919    document.querySelector("#container").appendChild(dynamicInput2);
    2020    dynamicInput2.setAttribute("type", "password");
  • trunk/LayoutTests/fast/forms/auto-fill-button/input-disabled-auto-fill-button.html

    r185166 r195685  
    66<script>
    77if (window.internals)
    8     internals.setShowAutoFillButton(document.getElementById("password"), true);
     8    internals.setShowAutoFillButton(document.getElementById("password"), "AutoFillButtonTypeCredentials");
    99</script>
    1010</body>
  • trunk/LayoutTests/fast/forms/auto-fill-button/input-readonly-auto-fill-button.html

    r185166 r195685  
    66<script>
    77if (window.internals)
    8     internals.setShowAutoFillButton(document.getElementById("password"), true);
     8    internals.setShowAutoFillButton(document.getElementById("password"), "AutoFillButtonTypeCredentials");
    99</script>
    1010</body>
  • trunk/LayoutTests/fast/forms/auto-fill-button/input-readonly-non-empty-auto-fill-button.html

    r185166 r195685  
    66<script>
    77if (window.internals)
    8     internals.setShowAutoFillButton(document.getElementById("password"), true);
     8    internals.setShowAutoFillButton(document.getElementById("password"), "AutoFillButtonTypeCredentials");
    99</script>
    1010</body>
  • trunk/LayoutTests/fast/forms/auto-fill-button/mouse-down-input-mouse-release-auto-fill-button.html

    r185341 r195685  
    2323        return;
    2424
    25     internals.setShowAutoFillButton(password, true);
     25    internals.setShowAutoFillButton(password, "AutoFillButtonTypeCredentials");
    2626
    27     var autoFillButton = getElementByPseudoId(internals.shadowRoot(password), "-webkit-auto-fill-button");
     27    var autoFillButton = getElementByPseudoId(internals.shadowRoot(password), "-webkit-credentials-auto-fill-button");
    2828    autoFillButton.onclick = checkEventAndDone;
    2929
  • trunk/Source/WebCore/ChangeLog

    r195682 r195685  
     12016-01-27  Zhuo Li  <zachli@apple.com>
     2
     3        Need ability to specify alternate image for AutoFill button in input fields.
     4        https://bugs.webkit.org/show_bug.cgi?id=153116.
     5        rdar://problem/23384854.
     6
     7        Reviewed by Darin Adler.
     8
     9        Add a new AutoFill button that can be shown in <input> elements.
     10
     11        Tests: fast/forms/auto-fill-button/input-contacts-auto-fill-button.html
     12               fast/forms/auto-fill-button/show-correct-auto-fill-button-when-auto-fill-button-type-changes.html
     13
     14        * css/html.css:
     15        (input::-webkit-contacts-auto-fill-button):
     16        (input::-webkit-contacts-auto-fill-button:hover):
     17        (input::-webkit-contacts-auto-fill-button:active):
     18        Add default style rules for the Contacts AutoFill button based on the ones used for
     19        Manual AutoFill button.
     20
     21        * html/HTMLInputElement.cpp:
     22        (WebCore::HTMLInputElement::setShowAutoFillButton):
     23        * html/HTMLInputElement.h:
     24        (WebCore::HTMLInputElement::autoFillButtonType):
     25        - Replace the boolean parameter with a new parameter to specify the type of the AutoFill button.
     26        - Declare a private variable to keep a record of the type of the current AutoFill
     27        button.
     28        (WebCore::HTMLInputElement::showAutoFillButton): Deleted.
     29
     30        * html/HTMLTextFormControlElement.h:
     31        Declare enum for AutoFill button type.
     32
     33        * html/TextFieldInputType.cpp:
     34        (WebCore::autoFillButtonTypeToAutoFillButtonPseudoClassName):
     35        (WebCore::isAutoFillButtonTypeChanged):
     36        (WebCore::TextFieldInputType::shouldDrawAutoFillButton): None means the AutoFill button is not
     37        enabled.
     38        (WebCore::TextFieldInputType::createAutoFillButton): Only create the AutoFill button
     39        if the type is expected.
     40        (WebCore::TextFieldInputType::updateAutoFillButton):
     41        Handle the case where AutoFill button type changes in the text field.
     42        * html/TextFieldInputType.h:
     43
     44        * testing/Internals.cpp:
     45        (WebCore::stringToAutoFillButtonType): Convert the string to AutoFill button type.
     46        (WebCore::Internals::setShowAutoFillButton): Add a new parameter to specify the type of the AutoFill button.
     47        * testing/Internals.h: Ditto.
     48        * testing/Internals.idl: Ditto.
     49
    1502016-01-26  Ryosuke Niwa  <rniwa@webkit.org>
    251
  • trunk/Source/WebCore/css/html.css

    r191751 r195685  
    550550}
    551551
    552 input::-webkit-auto-fill-button {
     552input::-webkit-credentials-auto-fill-button {
    553553    -webkit-mask-image: -webkit-image-set(url("") 1x, url("") 2x);
    554554    -webkit-mask-size: 15px 12px;
     
    562562}
    563563
    564 input::-webkit-auto-fill-button:hover {
     564input::-webkit-credentials-auto-fill-button:hover {
    565565    background-color: rgb(0, 122, 255);
    566566}
    567567
    568 input::-webkit-auto-fill-button:active {
     568input::-webkit-credentials-auto-fill-button:active {
     569    background-color: rgb(0, 60, 219);
     570}
     571
     572input::-webkit-contacts-auto-fill-button {
     573    -webkit-mask-image: -webkit-image-set(url("") 1x, url("") 2x);
     574    -webkit-mask-size: 15px 12px;
     575    width: 15px;
     576    height: 12px;
     577    margin-left: 3px;
     578    margin-right: 2px;
     579    background-color: black;
     580    flex: none;
     581    -webkit-user-select: none;
     582}
     583
     584input::-webkit-contacts-auto-fill-button:hover {
     585    background-color: rgb(0, 122, 255);
     586}
     587
     588input::-webkit-contacts-auto-fill-button:active {
    569589    background-color: rgb(0, 60, 219);
    570590}
  • trunk/Source/WebCore/html/HTMLInputElement.cpp

    r195642 r195685  
    106106    , m_autocomplete(Uninitialized)
    107107    , m_isAutoFilled(false)
    108     , m_showAutoFillButton(false)
     108    , m_autoFillButtonType(static_cast<uint8_t>(AutoFillButtonType::None))
    109109#if ENABLE(DATALIST_ELEMENT)
    110110    , m_hasNonEmptyList(false)
     
    13011301}
    13021302
    1303 void HTMLInputElement::setShowAutoFillButton(bool showAutoFillButton)
    1304 {
    1305     if (showAutoFillButton == m_showAutoFillButton)
     1303void HTMLInputElement::setShowAutoFillButton(AutoFillButtonType autoFillButtonType)
     1304{
     1305    if (static_cast<uint8_t>(autoFillButtonType) == m_autoFillButtonType)
    13061306        return;
    13071307
    1308     m_showAutoFillButton = showAutoFillButton;
     1308    m_autoFillButtonType = static_cast<uint8_t>(autoFillButtonType);
    13091309    m_inputType->updateAutoFillButton();
    13101310}
  • trunk/Source/WebCore/html/HTMLInputElement.h

    r194796 r195685  
    238238    WEBCORE_EXPORT void setAutoFilled(bool = true);
    239239
    240     bool showAutoFillButton() const { return m_showAutoFillButton; }
    241     WEBCORE_EXPORT void setShowAutoFillButton(bool);
     240    AutoFillButtonType autoFillButtonType() const { return (AutoFillButtonType)m_autoFillButtonType; }
     241    WEBCORE_EXPORT void setShowAutoFillButton(AutoFillButtonType);
    242242
    243243    FileList* files();
     
    432432    unsigned m_autocomplete : 2; // AutoCompleteSetting
    433433    bool m_isAutoFilled : 1;
    434     bool m_showAutoFillButton : 1;
     434    unsigned m_autoFillButtonType : 2; // AutoFillButtonType;
    435435#if ENABLE(DATALIST_ELEMENT)
    436436    bool m_hasNonEmptyList : 1;
  • trunk/Source/WebCore/html/HTMLTextFormControlElement.h

    r186256 r195685  
    3535class VisiblePosition;
    3636
     37enum class AutoFillButtonType : uint8_t { None, Credentials, Contacts };
    3738enum TextFieldSelectionDirection { SelectionHasNoDirection, SelectionHasForwardDirection, SelectionHasBackwardDirection };
    3839enum TextFieldEventBehavior { DispatchNoEvent, DispatchChangeEvent, DispatchInputAndChangeEvent };
  • trunk/Source/WebCore/html/TextFieldInputType.cpp

    r194496 r195685  
    400400}
    401401
     402static AtomicString autoFillButtonTypeToAutoFillButtonPseudoClassName(AutoFillButtonType autoFillButtonType)
     403{
     404    AtomicString pseudoClassName;
     405    switch (autoFillButtonType) {
     406    case AutoFillButtonType::Contacts:
     407        pseudoClassName = AtomicString("-webkit-contacts-auto-fill-button", AtomicString::ConstructFromLiteral);
     408        break;
     409    case AutoFillButtonType::Credentials:
     410        pseudoClassName = AtomicString("-webkit-credentials-auto-fill-button", AtomicString::ConstructFromLiteral);
     411        break;
     412    case AutoFillButtonType::None:
     413        ASSERT_NOT_REACHED();
     414        break;
     415    }
     416
     417    return pseudoClassName;
     418}
     419
     420static bool isAutoFillButtonTypeChanged(const AtomicString& attribute, AutoFillButtonType autoFillButtonType)
     421{
     422    if (attribute == "-webkit-contacts-auto-fill-button" && autoFillButtonType != AutoFillButtonType::Contacts)
     423        return true;
     424
     425    if (attribute == "-webkit-credentials-auto-fill-button" && autoFillButtonType != AutoFillButtonType::Credentials)
     426        return true;
     427
     428    return false;
     429}
     430
    402431String TextFieldInputType::sanitizeValue(const String& proposedValue) const
    403432{
     
    588617bool TextFieldInputType::shouldDrawAutoFillButton() const
    589618{
    590     return !element().isDisabledOrReadOnly() && element().showAutoFillButton();
     619    return !element().isDisabledOrReadOnly() && element().autoFillButtonType() != AutoFillButtonType::None;
    591620}
    592621
     
    614643}
    615644
    616 void TextFieldInputType::createAutoFillButton()
     645void TextFieldInputType::createAutoFillButton(AutoFillButtonType autoFillButtonType)
    617646{
    618647    ASSERT(!m_autoFillButton);
    619648
     649    if (autoFillButtonType == AutoFillButtonType::None)
     650        return;
     651
    620652    m_autoFillButton = AutoFillButtonElement::create(element().document(), *this);
    621     m_autoFillButton->setPseudo(AtomicString("-webkit-auto-fill-button", AtomicString::ConstructFromLiteral));
     653    m_autoFillButton->setPseudo(autoFillButtonTypeToAutoFillButtonPseudoClassName(autoFillButtonType));
    622654    m_container->appendChild(*m_autoFillButton, IGNORE_EXCEPTION);
    623655}
     
    630662
    631663        if (!m_autoFillButton)
    632             createAutoFillButton();
     664            createAutoFillButton(element().autoFillButtonType());
     665
     666        const AtomicString& attribute = m_autoFillButton->fastGetAttribute(pseudoAttr);
     667        bool shouldUpdateAutoFillButtonType = isAutoFillButtonTypeChanged(attribute, element().autoFillButtonType());
     668        if (shouldUpdateAutoFillButtonType)
     669            m_autoFillButton->setPseudo(autoFillButtonTypeToAutoFillButtonPseudoClassName(element().autoFillButtonType()));
    633670
    634671        m_autoFillButton->setInlineStyleProperty(CSSPropertyDisplay, CSSValueBlock, true);
  • trunk/Source/WebCore/html/TextFieldInputType.h

    r191188 r195685  
    109109
    110110    void createContainer();
    111     void createAutoFillButton();
     111    void createAutoFillButton(AutoFillButtonType);
    112112
    113113    RefPtr<HTMLElement> m_container;
  • trunk/Source/WebCore/testing/Internals.cpp

    r195646 r195685  
    12791279}
    12801280
    1281 void Internals::setShowAutoFillButton(Element* element, bool show, ExceptionCode& ec)
     1281static AutoFillButtonType stringToAutoFillButtonType(const String& autoFillButtonType)
     1282{
     1283    if (autoFillButtonType == "AutoFillButtonTypeNone")
     1284        return AutoFillButtonType::None;
     1285    if (autoFillButtonType == "AutoFillButtonTypeCredentials")
     1286        return AutoFillButtonType::Credentials;
     1287    if (autoFillButtonType == "AutoFillButtonTypeContacts")
     1288        return AutoFillButtonType::Contacts;
     1289    ASSERT_NOT_REACHED();
     1290    return AutoFillButtonType::None;
     1291}
     1292
     1293void Internals::setShowAutoFillButton(Element* element, const String& autoFillButtonType, ExceptionCode& ec)
    12821294{
    12831295    if (!element) {
     
    12911303    }
    12921304
    1293     downcast<HTMLInputElement>(*element).setShowAutoFillButton(show);
     1305    downcast<HTMLInputElement>(*element).setShowAutoFillButton(stringToAutoFillButtonType(autoFillButtonType));
    12941306}
    12951307
  • trunk/Source/WebCore/testing/Internals.h

    r195515 r195685  
    178178    void setEditingValue(Element* inputElement, const String&, ExceptionCode&);
    179179    void setAutofilled(Element*, bool enabled, ExceptionCode&);
    180     void setShowAutoFillButton(Element*, bool enabled, ExceptionCode&);
     180    void setShowAutoFillButton(Element*, const String& autoFillButtonType, ExceptionCode&);
    181181    void scrollElementToRect(Element*, long x, long y, long w, long h, ExceptionCode&);
    182182
  • trunk/Source/WebCore/testing/Internals.idl

    r195515 r195685  
    5858};
    5959
     60enum AutoFillButtonType {
     61    "AutoFillButtonTypeNone",
     62    "AutoFillButtonTypeContacts",
     63    "AutoFillButtonTypeCredentials"
     64};
     65
    6066[
    6167    NoInterfaceObject,
     
    152158    [RaisesException] void setEditingValue(Element inputElement, DOMString value);
    153159    [RaisesException] void setAutofilled(Element inputElement, boolean enabled);
    154     [RaisesException] void setShowAutoFillButton(Element inputElement, boolean enabled);
     160    [RaisesException] void setShowAutoFillButton(Element inputElement, AutoFillButtonType autoFillButtonType);
    155161    [RaisesException] unsigned long countMatchesForText(DOMString text, unsigned long findOptions, DOMString markMatches);
    156162
  • trunk/Source/WebKit2/ChangeLog

    r195677 r195685  
     12016-01-27  Zhuo Li  <zachli@apple.com>
     2
     3        Need ability to specify alternate image for AutoFill button in input fields.
     4        https://bugs.webkit.org/show_bug.cgi?id=153116.
     5        rdar://problem/23384854.
     6
     7        Reviewed by Darin Adler.
     8
     9        * WebProcess/InjectedBundle/API/c/WKBundleNodeHandle.cpp:
     10        (toAutoFillButtonType): Convert the WebKit AutoFill button type enum to WebCore AutoFill button
     11        type enum.
     12        (WKBundleNodeHandleSetHTMLInputElementAutoFillButtonEnabledWithButtonType): Added to be able to specify
     13        what the AutoFill button type is. None means the AutoFill button is not shown.
     14        (WKBundleNodeHandleSetHTMLInputElementAutoFillButtonEnabled): Deprecate this method.
     15        * WebProcess/InjectedBundle/API/c/WKBundleNodeHandlePrivate.h: Declare an AutoFill button type enum.
     16        * WebProcess/InjectedBundle/DOM/InjectedBundleNodeHandle.cpp:
     17        (WebKit::InjectedBundleNodeHandle::isHTMLInputElementAutoFillButtonEnabled): None means the AutoFill button is not enabled.
     18        (WebKit::InjectedBundleNodeHandle::setHTMLInputElementAutoFillButtonEnabledWithButtonType): Use the new parameter to specify
     19        what the AutoFill button type is.
     20        * WebProcess/InjectedBundle/DOM/InjectedBundleNodeHandle.h: Ditto.
     21
    1222016-01-27  Dan Bernstein  <mitz@apple.com>
    223
  • trunk/Source/WebKit2/WebProcess/InjectedBundle/API/c/WKBundleNodeHandle.cpp

    r181408 r195685  
    3434#include "WebFrame.h"
    3535#include "WebImage.h"
     36#include <WebCore/HTMLTextFormControlElement.h>
    3637
    3738using namespace WebKit;
     39
     40static WebCore::AutoFillButtonType toAutoFillButtonType(WKAutoFillButtonType wkAutoFillButtonType)
     41{
     42    switch (wkAutoFillButtonType) {
     43    case kWKAutoFillButtonTypeNone:
     44        return WebCore::AutoFillButtonType::None;
     45    case kWKAutoFillButtonTypeContacts:
     46        return WebCore::AutoFillButtonType::Contacts;
     47    case kWKAutoFillButtonTypeCredentials:
     48        return WebCore::AutoFillButtonType::Credentials;
     49    }
     50    ASSERT_NOT_REACHED();
     51    return WebCore::AutoFillButtonType::None;
     52}
    3853
    3954WKTypeID WKBundleNodeHandleGetTypeID()
     
    96111}
    97112
    98 void WKBundleNodeHandleSetHTMLInputElementAutoFillButtonEnabled(WKBundleNodeHandleRef htmlInputElementHandleRef, bool enabled)
     113void WKBundleNodeHandleSetHTMLInputElementAutoFillButtonEnabledWithButtonType(WKBundleNodeHandleRef htmlInputElementHandleRef, WKAutoFillButtonType autoFillButtonType)
    99114{
    100     toImpl(htmlInputElementHandleRef)->setHTMLInputElementAutoFillButtonEnabled(enabled);
     115    toImpl(htmlInputElementHandleRef)->setHTMLInputElementAutoFillButtonEnabled(toAutoFillButtonType(autoFillButtonType));
    101116}
    102117
     
    151166    toImpl(htmlInputElementHandleRef)->setHTMLInputElementAutoFilled(filled);
    152167}
     168
     169// Deprecated - use WKBundleNodeHandleSetHTMLInputElementAutoFillButtonEnabledWithButtonType(WKBundleNodeHandleRef, WKAutoFillButtonType).
     170void WKBundleNodeHandleSetHTMLInputElementAutoFillButtonEnabled(WKBundleNodeHandleRef htmlInputElementHandleRef, bool enabled)
     171{
     172    WebCore::AutoFillButtonType autoFillButtonType = enabled ? WebCore::AutoFillButtonType::Credentials : WebCore::AutoFillButtonType::None;
     173
     174    toImpl(htmlInputElementHandleRef)->setHTMLInputElementAutoFillButtonEnabled(autoFillButtonType);
     175}
  • trunk/Source/WebKit2/WebProcess/InjectedBundle/API/c/WKBundleNodeHandlePrivate.h

    r181408 r195685  
    3636#endif
    3737
     38enum {
     39    kWKAutoFillButtonTypeNone,
     40    kWKAutoFillButtonTypeCredentials,
     41    kWKAutoFillButtonTypeContacts
     42};
     43typedef uint8_t WKAutoFillButtonType;
     44
    3845WK_EXPORT WKBundleNodeHandleRef WKBundleNodeHandleCreate(JSContextRef context, JSObjectRef object);
    3946
     
    5663WK_EXPORT void WKBundleNodeHandleSetHTMLInputElementAutoFilled(WKBundleNodeHandleRef htmlInputElementHandle, bool filled);
    5764WK_EXPORT bool WKBundleNodeHandleGetHTMLInputElementAutoFillButtonEnabled(WKBundleNodeHandleRef htmlInputElementHandle);
    58 WK_EXPORT void WKBundleNodeHandleSetHTMLInputElementAutoFillButtonEnabled(WKBundleNodeHandleRef htmlInputElementHandle, bool enabled);
     65WK_EXPORT void WKBundleNodeHandleSetHTMLInputElementAutoFillButtonEnabledWithButtonType(WKBundleNodeHandleRef htmlInputElementHandle, WKAutoFillButtonType autoFillButtonType);
    5966WK_EXPORT WKRect WKBundleNodeHandleGetHTMLInputElementAutoFillButtonBounds(WKBundleNodeHandleRef htmlInputElementHandle);
    6067WK_EXPORT bool WKBundleNodeHandleGetHTMLInputElementLastChangeWasUserEdit(WKBundleNodeHandleRef htmlInputElementHandle);
     
    8087/* Deprecated - use WKBundleNodeHandleSetHTMLInputElementAutoFilled(WKBundleNodeHandleRef, bool) */
    8188WK_EXPORT void WKBundleNodeHandleSetHTMLInputElementAutofilled(WKBundleNodeHandleRef htmlInputElementHandle, bool filled);
     89/* Deprecated - use WKBundleNodeHandleSetHTMLInputElementAutoFillButtonEnabled(WKBundleNodeHandleRef, WKAutoFillButtonType)*/
     90WK_EXPORT void WKBundleNodeHandleSetHTMLInputElementAutoFillButtonEnabled(WKBundleNodeHandleRef htmlInputElementHandle, bool enabled);
    8291
    8392#ifdef __cplusplus
  • trunk/Source/WebKit2/WebProcess/InjectedBundle/DOM/InjectedBundleNodeHandle.cpp

    r189144 r195685  
    232232        return false;
    233233   
    234     return downcast<HTMLInputElement>(m_node.get()).showAutoFillButton();
    235 }
    236 
    237 void InjectedBundleNodeHandle::setHTMLInputElementAutoFillButtonEnabled(bool filled)
     234    return downcast<HTMLInputElement>(m_node.get()).autoFillButtonType() != AutoFillButtonType::None;
     235}
     236
     237void InjectedBundleNodeHandle::setHTMLInputElementAutoFillButtonEnabled(AutoFillButtonType autoFillButtonType)
    238238{
    239239    if (!is<HTMLInputElement>(m_node))
    240240        return;
    241241
    242     downcast<HTMLInputElement>(m_node.get()).setShowAutoFillButton(filled);
     242    downcast<HTMLInputElement>(m_node.get()).setShowAutoFillButton(autoFillButtonType);
    243243}
    244244
  • trunk/Source/WebKit2/WebProcess/InjectedBundle/DOM/InjectedBundleNodeHandle.h

    r181408 r195685  
    3737    class IntRect;
    3838    class Node;
     39    enum class AutoFillButtonType : uint8_t;
    3940}
    4041
     
    6970    void setHTMLInputElementAutoFilled(bool);
    7071    bool isHTMLInputElementAutoFillButtonEnabled() const;
    71     void setHTMLInputElementAutoFillButtonEnabled(bool);
     72    void setHTMLInputElementAutoFillButtonEnabled(WebCore::AutoFillButtonType);
    7273    WebCore::IntRect htmlInputElementAutoFillButtonBounds();
    7374    bool htmlInputElementLastChangeWasUserEdit();
Note: See TracChangeset for help on using the changeset viewer.