mirror of
https://github.com/silverstripe/silverstripe-userforms.git
synced 2024-10-22 15:05:42 +00:00
BUG Fix the 'always modified' label in treeview. Fixes #48.
userforms always reported 'modified' in the sitetree. Fixed the issue by checking the userdefinedform record and the formfields.
This commit is contained in:
parent
0aa9572f2c
commit
75c6d40fa4
@ -1,11 +1,6 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* User Defined Form Page type that lets users build a form in the CMS
|
|
||||||
* using the FieldEditor Field.
|
|
||||||
*
|
|
||||||
* @todo Allow UserDefinedForm instances on Page subclasses (eg via decorator)
|
|
||||||
*
|
|
||||||
* @package userforms
|
* @package userforms
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -102,8 +97,6 @@ class UserDefinedForm extends Page {
|
|||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Publishing Versioning support.
|
|
||||||
*
|
|
||||||
* When publishing copy the editable form fields to the live database
|
* When publishing copy the editable form fields to the live database
|
||||||
* Not going to version emails and submissions as they are likely to
|
* Not going to version emails and submissions as they are likely to
|
||||||
* persist over multiple versions
|
* persist over multiple versions
|
||||||
@ -131,10 +124,8 @@ class UserDefinedForm extends Page {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Unpublishing Versioning support
|
* When un-publishing the page it has to remove all the fields from the
|
||||||
*
|
* live database table.
|
||||||
* When unpublishing the page it has to remove all the fields from
|
|
||||||
* the live database table
|
|
||||||
*
|
*
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
@ -151,7 +142,7 @@ class UserDefinedForm extends Page {
|
|||||||
/**
|
/**
|
||||||
* Roll back a form to a previous version.
|
* Roll back a form to a previous version.
|
||||||
*
|
*
|
||||||
* @param String|int Version to roll back to
|
* @param string|int Version to roll back to
|
||||||
*/
|
*/
|
||||||
public function doRollbackTo($version) {
|
public function doRollbackTo($version) {
|
||||||
parent::doRollbackTo($version);
|
parent::doRollbackTo($version);
|
||||||
@ -256,7 +247,7 @@ class UserDefinedForm extends Page {
|
|||||||
* Custom options for the form. You can extend the built in options by
|
* Custom options for the form. You can extend the built in options by
|
||||||
* using {@link updateFormOptions()}
|
* using {@link updateFormOptions()}
|
||||||
*
|
*
|
||||||
* @return FieldSet
|
* @return FieldList
|
||||||
*/
|
*/
|
||||||
public function getFormOptions() {
|
public function getFormOptions() {
|
||||||
$submit = ($this->SubmitButtonText) ? $this->SubmitButtonText : _t('UserDefinedForm.SUBMITBUTTON', 'Submit');
|
$submit = ($this->SubmitButtonText) ? $this->SubmitButtonText : _t('UserDefinedForm.SUBMITBUTTON', 'Submit');
|
||||||
@ -275,20 +266,34 @@ class UserDefinedForm extends Page {
|
|||||||
* Return if this form has been modified on the stage site and not published.
|
* Return if this form has been modified on the stage site and not published.
|
||||||
* this is used on the workflow module and for a couple highlighting things
|
* this is used on the workflow module and for a couple highlighting things
|
||||||
*
|
*
|
||||||
* @todo make this a bit smarter - the issue with userforms is that it uses several
|
* @return boolean
|
||||||
* relationships to form fields which has a undefined amount of options so
|
|
||||||
* for now just say its always modified
|
|
||||||
*/
|
*/
|
||||||
public function getIsModifiedOnStage() {
|
public function getIsModifiedOnStage() {
|
||||||
return true;
|
// new unsaved pages could be never be published
|
||||||
|
if($this->isNew()) return false;
|
||||||
|
|
||||||
|
$stageVersion = Versioned::get_versionnumber_by_stage('UserDefinedForm', 'Stage', $this->ID);
|
||||||
|
$liveVersion = Versioned::get_versionnumber_by_stage('UserDefinedForm', 'Live', $this->ID);
|
||||||
|
|
||||||
|
$isModified = ($stageVersion && $stageVersion != $liveVersion);
|
||||||
|
if (!$isModified) {
|
||||||
|
if($this->Fields()) {
|
||||||
|
foreach($this->Fields() as $field) {
|
||||||
|
if ($field->getIsModifiedOnStage()) {
|
||||||
|
$isModified = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $isModified;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Controller for the {@link UserDefinedForm} page type.
|
* Controller for the {@link UserDefinedForm} page type.
|
||||||
*
|
*
|
||||||
* @package userform
|
* @package userforms
|
||||||
* @subpackage pagetypes
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
class UserDefinedForm_Controller extends Page_Controller {
|
class UserDefinedForm_Controller extends Page_Controller {
|
||||||
|
@ -107,6 +107,31 @@ class EditableFormField extends DataObject {
|
|||||||
$this->deleteFromStage($stage);
|
$this->deleteFromStage($stage);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* checks wether record is new, copied from Sitetree
|
||||||
|
*/
|
||||||
|
function isNew() {
|
||||||
|
if(empty($this->ID)) return true;
|
||||||
|
|
||||||
|
if(is_numeric($this->ID)) return false;
|
||||||
|
|
||||||
|
return stripos($this->ID, 'new') === 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* checks if records is changed on stage
|
||||||
|
* @return boolean
|
||||||
|
*/
|
||||||
|
public function getIsModifiedOnStage() {
|
||||||
|
// new unsaved fields could be never be published
|
||||||
|
if($this->isNew()) return false;
|
||||||
|
|
||||||
|
$stageVersion = Versioned::get_versionnumber_by_stage('EditableFormField', 'Stage', $this->ID);
|
||||||
|
$liveVersion = Versioned::get_versionnumber_by_stage('EditableFormField', 'Live', $this->ID);
|
||||||
|
|
||||||
|
return ($stageVersion && $stageVersion != $liveVersion);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Show this form on load or not
|
* Show this form on load or not
|
||||||
|
@ -211,16 +211,6 @@ class UserDefinedFormTest extends FunctionalTest {
|
|||||||
$this->assertEquals($form->Fields()->First()->Title, $duplicate->Fields()->First()->Title);
|
$this->assertEquals($form->Fields()->First()->Title, $duplicate->Fields()->First()->Title);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @todo once getIsModifiedOnStage is implemented will need to implement this
|
|
||||||
*/
|
|
||||||
function testGetIsModifiedOnStage() {
|
|
||||||
$this->logInWithPermission('ADMIN');
|
|
||||||
$form = $this->objFromFixture('UserDefinedForm', 'basic-form-page');
|
|
||||||
|
|
||||||
$this->assertTrue($form->getIsModifiedOnStage());
|
|
||||||
}
|
|
||||||
|
|
||||||
function testFormOptions() {
|
function testFormOptions() {
|
||||||
$this->logInWithPermission('ADMIN');
|
$this->logInWithPermission('ADMIN');
|
||||||
$form = $this->objFromFixture('UserDefinedForm', 'basic-form-page');
|
$form = $this->objFromFixture('UserDefinedForm', 'basic-form-page');
|
||||||
|
Loading…
x
Reference in New Issue
Block a user