From ba13f1a5da77acd41db6d1bee001a95aec7d53ec Mon Sep 17 00:00:00 2001 From: Mike G Date: Wed, 29 Nov 2017 20:51:51 +1100 Subject: [PATCH] Changed EditForm to scroll quicker for longer forms Updated version to 4.0.0-beta.7.3 --- .../App/screens/Item/components/EditForm.js | 26 ++++++++++++------- package.json | 2 +- 2 files changed, 17 insertions(+), 11 deletions(-) diff --git a/admin/client/App/screens/Item/components/EditForm.js b/admin/client/App/screens/Item/components/EditForm.js index 7163ce3bed..bf981f32cf 100644 --- a/admin/client/App/screens/Item/components/EditForm.js +++ b/admin/client/App/screens/Item/components/EditForm.js @@ -41,9 +41,15 @@ function getNameFromData (data) { } function smoothScrollTop () { + var scrollTotal = document.body.scrollTop || document.documentElement.scrollTop || -1; + // Smooth scroll is too slow for items with lots of fields so we speed it up and do a basic ease in + var scrollSpeed = scrollTotal * -0.50; + if (document.body.scrollTop || document.documentElement.scrollTop) { - window.scrollBy(0, -50); - var timeOut = setTimeout(smoothScrollTop, 20); + window.scrollBy(0, scrollSpeed); + var timeOut = setTimeout(function () { + smoothScrollTop(); + }, 20); } else { clearTimeout(timeOut); } @@ -306,7 +312,7 @@ var EditForm = React.createClass({ var headings = 0; return this.props.list.uiElements.map((el, index) => { - + // Don't render the name field if it is the header since it'll be rendered in BIG above // the list. (see renderNameField method, this is the reverse check of the one it does) if ( @@ -323,14 +329,14 @@ var EditForm = React.createClass({ } if (el.type === 'field') { - + var field = this.props.list.fields[el.field]; var props = this.getFieldProps(field); - console.log('form field: ' +field.type + ' '+ field.path); + console.log('form field: ' + field.type + ' ' + field.path); if (typeof Fields[field.type] !== 'function') { - + return React.createElement(InvalidFieldType, { type: field.type, path: field.path, key: field.path }); - + } props.key = field.path; if (index === 0 && this.state.focusFirstField) { @@ -394,13 +400,13 @@ var EditForm = React.createClass({ // Only show Approve button is there is pending approval and user has permissions if (this.state.values['publishing.pendingApproval'] || (currentState !== requestState)) { - if(this.canUserApprove()){ + if (this.canUserApprove()) { _approveButtonDisabled = false; - } else{ + } else { _approveButtonDisabled = true; approveButtonText = upcase(currentState) + '->' + upcase(requestState); } - + } else { _approveButtonDisabled = true; approveButtonText = upcase(currentState); diff --git a/package.json b/package.json index db5a1c5b85..22b9cf7fe4 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "keystone", - "version": "4.0.0-beta.7.2", + "version": "4.0.0-beta.7.3", "description": "Web Application Framework and Admin GUI / Content Management System built on Express.js and Mongoose", "main": "index.js", "repository": {