Как использовать поле ввода внутри панели стыковки Autodesk Viewer API? - PullRequest
0 голосов
/ 28 апреля 2020

Я пытался добавить счетчик приращений и приращений внутри стыковочной панели в программе просмотра Autodesk.

Я даже пробовал с базовым полем ввода текста c внутри него. Это не работает. Панель вместе с полем ввода отображается нормально. Но почему я не могу его использовать? Например, если это поле ввода, я не включен, не могу напечатать или изменить его значение. В случае со счетчиком тоже самое.

Это сделано нарочно? Если это так, я видел приложения, использующие такие счетчики, как входы. Может кто-нибудь сказать мне, что не так с моим подходом?

Пример кода, который я пробовал, приведен ниже,

Снимок экрана: https://i.stack.imgur.com/hyEBr.png

Примечание: я также пробовал с простым полем ввода текста вместо счетчика, он работает так же

Редактировать: отключение обработчика перемещения из Контейнер решил эту проблему. Комментирование от samuel-middendorp помогло.

    <head>
        <meta name="viewport" content="width=device-width, minimum-scale=1.0, initial-scale=1, user-scalable=no" />
        <meta charset="utf-8">

        <link rel="stylesheet" href="https://developer.api.autodesk.com/modelderivative/v2/viewers/7.*/style.min.css" type="text/css">
        <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>
        <script src="https://developer.api.autodesk.com/modelderivative/v2/viewers/7.*/viewer3D.min.js"></script>
        <style>
            body {
                margin: 0;
            }
            #forgeViewer {
                width: 100%;
                height: 100%;
                margin: 0;
                background-color: #F0F8FF;
            }

            </style>
    </head>
    <body>
        <div id="forgeViewer"></div>
    </body>
   <script>

   var viewer;
   var closable = null;
    var options = {
        env: 'AutodeskProduction',
        api: 'derivativeV2',  // for models uploaded to EMEA change this option to 'derivativeV2_EU'
        getAccessToken: function(onTokenReady) {
            var token = 'access token';
            var timeInSeconds = 3600; // Use value provided by Forge Authentication (OAuth) API
            onTokenReady(token, timeInSeconds);
        }
    };

SimplePanel = function(parentContainer, id, title, content, x, y)
{
  this.content = content;
Autodesk.Viewing.UI.DockingPanel.call(this, parentContainer, id, title,{shadow:false});

// Auto-fit to the content and don't allow resize.  Position at the coordinates given.

this.container.style.height = "250px";
this.container.style.width = "450px";
this.container.style.resize = "auto";
this.container.style.left = x + "px";
this.container.style.top = y + "px"; 
this.container.style.zIndex = 2;

};

SimplePanel.prototype = Object.create(Autodesk.Viewing.UI.DockingPanel.prototype);
SimplePanel.prototype.constructor = SimplePanel;

SimplePanel.prototype.initialize = function()
{ 
        this.title = this.createTitleBar(this.titleLabel || this.container.id);
this.container.appendChild(this.title);

this.container.appendChild(this.content);
this.initializeMoveHandlers(this.container);

this.closer = document.createElement("span");
this.closer = this.createCloseButton();
this.initializeCloseHandler(this.closer);
this.container.appendChild(this.closer);

var op = {left:false,heightAdjustment:45,marginTop:0};
this.scrollcontainer = this.createScrollContainer(op);

var id = viewer.getSelection();
var dataItem;
var data = [
    {
        id:"2648",
        name:"Chiller",
        temp:"300 deg",
        serviceReq:5,
        reservations:"3"
    },
    {
        id:"2228",
        name:"Door",
        temp:"150 deg",
        serviceReq:2,
        reservations:"4"
    },
    {
        id:"2198",
        name:"Cooler",
        temp:"400 deg",
        serviceReq:6,
        reservations:"2"
    }
]

data.forEach(item => {
    if(item.id == id){
        dataItem = item;
    }
})

//this is the portion I have the issue - here I appending an input tag inside of a table cell. But the problem is the input field is not focussing,can't able to edit, not enabled 

var html = [
    '<table>',
    '<thead>',
    '<th>Key</th><th>Value</th>',
    '</thead>',
    '<tbody>',
    '<tr><td>ID</td><td>'+dataItem.id+'</td></tr>',
    '<tr><td>Name</td><td>'+dataItem.name+'</td></tr>',
    '<tr><td>Temperature</td><td>'+dataItem.temp+'</td></tr>',
    '<tr><td>Service Requests</td><td contenteditable="true"> <input type=“text”/></td></tr>',
    '<tr><td>Reservations</td><td>'+dataItem.reservations+'</td></tr>',
    '</tbody>',
    '</table>',
].join('\n');


$(this.scrollContainer).append(html);

this.initializeMoveHandlers(this.title);    
};

    Autodesk.Viewing.Initializer(options, function() {   
    var htmlDiv = document.getElementById('forgeViewer');
    viewer = new Autodesk.Viewing.GuiViewer3D(htmlDiv,{ extensions: ['CustomPropertyPanelExtension'] });
    var startedCode = viewer.start();
    if (startedCode > 0) {
        console.error('Failed to create a Viewer: WebGL not supported.');
        return;
    }

    console.log('Initialization complete, loading a model next...');

});

var documentId = 'urn:my urn';
Autodesk.Viewing.Document.load(documentId, onDocumentLoadSuccess, onDocumentLoadFailure);

function onDocumentLoadSuccess(viewerDocument) {

    var defaultModel = viewerDocument.getRoot().getDefaultGeometry();
    viewer.loadDocumentNode(viewerDocument, defaultModel);
    viewer.addEventListener( Autodesk.Viewing.SELECTION_CHANGED_EVENT, event=>{

        if( closable != null ) {
           closable.uninitialize();
           closable = null;
        }
        var content = document.createElement('div');
        var mypanel = new  SimplePanel(NOP_VIEWER.container,'mypanel','Asset properties',content,20,20);
        closable = mypanel;
        mypanel.setVisible(true);
})
}

function onDocumentLoadFailure() {
    console.error('Failed fetching Forge manifest');
}
   </script>
</html>


1 Ответ

0 голосов
/ 28 апреля 2020

Редактировать

Если вы настаиваете на перетаскивании контейнера прокрутки, что для меня выглядит довольно не интуитивно, вы можете легко остановить захват / перехват событий (mousedown) на входе с помощью обработчиков, включенных в контейнере (что возвращает нас к тому, как обработчики панелей могли бы захватывать события вместо того, чтобы позволять им всплывать, хотя ...

См. обновленный образец здесь

inputElement.addEventListener('mousedown',e=>e.stopPropagation())

Оригинальный ответ

К сожалению, я не смог воспроизвести проблемы с моим собственным примером здесь - вход работает как на панели:

Node.js

innerHTML=[
    '<table>',
    '<thead>',
    '<th>Key</th><th>Value</th>',
    '</thead>',
    '<tbody>',
    '<tr><td>ID</td><td>233</td></tr>',
    '<tr><td>Name</td><td>233</td></tr>',
    '<tr><td>Temperature</td><td>233</td></tr>',
    '<tr><td>Service Requests</td><td contenteditable="true"> <input type=“text”/></td></tr>',
    '<tr><td>Reservations</td><td>233</td></tr>',
    '</tbody>',
    '</table>',
].join('\n')  

Похоже, что проблема не совсем воспроизводима без вашего другого кода и / или CSS, который возможно, это было проблематично c, так что вы можете клонировать и добавить свой собственный код для воспроизведения ошибки и комментария ниже, чтобы я мог проверить ??

РЕДАКТИРОВАТЬ

Все еще не мог повторить проблему ... tr Я сделал вашу живую демонстрацию (рабочая здесь , ваша истекла ...) на Firefox (62.0) и Chrome (81), и входы работали должным образом:

enter image description here

...