Contact us

Sign up | United States |

Login

remember me

Go to my home page

Stay on current page

Recursive Phone Filter / Revisiting Validation




Visitors to VTC.com will be able to view all introductory videos for each training course.
Free Trial Members will gain access to first three chapters for each training course.
Full Access Members have full access to VTC.com�s entire library of video tutorials.


Learn More

Subtitles of the Movie (FileMaker Pro 11: Advanced / Recursive Phone Filter / Revisiting Validation)

When we started this chapter we were talking about Phone Formatting Recursion and we created a Custom function to recursively format phone numbers of any length and then we went off on a tangent to cover other types of Preferences because we included a Preference for phone formatting so that you could specify what phone formatting you wanted rather than having to modify the calculation, so we spent some time on that Preferences section but we're going to come back to our Phone Formatting Recursive function because there's a few problems with it and let's demonstrate. If we add a customer here you can see that it's already formatted the phone number even though there's nothing in there and that's really kind of confusing. It makes it difficult to use. And if we come in here and type in something like 123, which isn't the right number, it comes up and gives us an erroneous message that says it must have 7 or 10 digits. That's not correct; we're allowing any number of digits. And it formats it incorrectly. You can see it's added in some formatting here in addition to what it had. So it's completely wrong. We need to fix this. We need to make it so it's more dynamic, so it pays attention to that Recursive function and the Preferences and all that kind of stuff. So let's revert this record and we're going to go into Manage, Database. We'll find the phone field and we'll start with the Auto-Enter here. Go to the Auto-Enter section and let's change this. All we need is a Case statement here. Now, we're not modifying the Recursive Custom function because the things we're going to do can't be done inside of a Recursive Custom function and you'll see why in a second. We're going to type in not isempty open paren Self and then Length of Filter of Self quote 0123456789, just like we've done before. We're going to check the length of that and see if it equals the Length of Filter and we're going to go over to our OPTIONS Customers, double-click on phone format semicolon, we're going to keep only the pound signs, because that's the number of digits it should have, it's minus all that formatting that's in there. So, if there's something inside of the phone field, the Self and the Length of our numbers inside of that equal the Length of our Filter, just the pound signs, then we can go ahead and run the Recursion successfully, otherwise we want to return Self. Now there's two reasons. Self, if we don't put Self here it'll eliminate what they've typed in and, but more importantly, if we eliminate what we've typed in by not putting Self here and just having it result in nothing then Validation won't have anything to work on and tell them what went wrong, so these two have to work together. Auto-Enter happens before Validation so we have to make sure that works. So that's the formula for that. And let's come back in here real quick before I forget, why can't we do it inside our Recursion, our Custom function? Well, we only want this part to happen once. We only want it to check to see if it's empty or not and whether the length is correct or not. In fact, we can't even really check it in Recursion because it's going to be feeding in those parameters over and over by subtracting from that length of that number in the formatting and we won't be able to check this and see what length it is. We only want to check it once and it would really be impossible to do it because that value keeps changing and it will, after the first Recursion, it'll go ahead and fail because it's going to take off values from here, so we really can't do that. So we'll come into our Validation and fix this and we'll start with this message here. It's not accurate anymore and we can't be very accurate like we did inside our Auto-Enter by checking how long our, the format, how many pound signs we have in there. We can't do that because you can't put a calculation in here. But we'll revisit this later with Script Triggers. For right now we're going to put a very generalized message, something like: Phone numbers, or we'll say, The phone number entered has the wrong number of digits. That looks good. And then we'll go to our Validation formula, take a look at that. I'm going to change this. We're going to grab this and copy to the Clipboard and replace it right here and the reason for that is we don't have to check for 7 digits anymore, so we don't need this code. It's really kind of pointless to have this in here if you're not repeating the code over and over again. So we're going to go down to just this. We also have to check one other thing so let's go in there. We don't want to check against 10 we want to check against the values we have over here in our Auto-Enter, which is this right here. So we'll copy this, make it easy on ourselves, go over to our Validation and put that in there. And then we also want to check to see if it's empty or not. So isempty Self or the Length equals that and oops, I made a mistake there. So if it's empty don't validate or, if this equals this, in other words, the length of what we typed in equals the length of our phone formatting just like before, then don't validate, otherwise any other situation validate. So we're going to take this and copy this code to the Clipboard, come over to our other field, phone-s and paste it right in there. And then we'll come in here to our Auto-Enter, copy that and paste it to our phone-s, there we go and then we'll come back in here to our phone and get our Validation message, we'll copy that, and paste it into here. Well, it looks like we have everything. We'll double check it. I've got this new formula here, got the message, I've got this calculated value, it looks good. Now we can test it out and see if it works. We're going to add a new customer. You can see it hasn't automatically formatted already. I can type in 123, tab, or Commit the record. Phone number entered was the wrong number of digits. That's good. We'll hit No. You can see it hasn't formatted, it left what we have. We can go in and type in the rest of the digits and it formats correctly and doesn't require me to fill this one in. So now it works really great. It validates in the right situations and it Auto-Enters in the right situations. So this will complete our Phone Recursion Calculation by adding in some additional logic into the actual calculation, not into the Recursive Custom function.

Tutorial Information

Course: FileMaker Pro 11: Advanced
Author: John Mark Osborne
SKU: 34140
ISBN: 1-936334-36-4
Release Date: 2010-07-09
Duration: 14.5 hrs / 159 lessons
Work Files: Yes
Captions: No
Compatibility: Vista/XP/2000, OS X, Linux
QuickTime 7, Flash 8

VTC Sign up & Benefits

  • Unlimited Access
  • 81,350 Video Tutorials (14,200 free)
  • Video Available as Flash or QuickTime
  • Over 715 Courses
  • $30 for One Month Access
  • Multi-User Discounts Available

VTC Terms and Conditions

TERMS & CONDITIONS OF USE

BY SUBSCRIBING TO THIS SERVICE, YOU ARE CONSENTING TO BE BOUND BY AND ARE BECOMING A PARTY TO THIS AGREEMENT, THE TERMS AND CONDITIONS OF WHICH SHALL PREVAIL IN GOVERNING YOUR RIGHTS OF USE. BY CLICKING THE "BECOME A MEMBER" BUTTON, THE INDIVIDUAL OR ENTITY LICENSING THE PRODUCT ("YOU") IS CONSENTING TO BE BOUND BY AND IS BECOMING A PARTY TO THIS AGREEMENT. IF LICENSEE DOES NOT AGREE TO ALL OF THE TERMS OF THIS AGREEMENT, THE BUTTON INDICATING "BECOME A MEMBER" MUST NOT BE SELECTED, AND LICENSEE MUST NOT INSTALL OR USE THE SOFTWARE.

1. DEFINITIONS

"VTC" refers to Virtual Training Company, Inc.
"You" refers to the user or subscriber.
"Software" refers to the VTC training content and software.

2. LICENSE: VTC hereby grants to You a worldwide, non-royalty bearing, non-exclusive license to use the Software according to the provisions contained herein and subject to payment of the applicable subscription fees.

3. RESTRICTIONS: You may not do any of the following:

Save the Software to Your hard disk or other storage medium; permit others to use the Software except as specified by addendum; modify, reverse engineer, decompile, or disassemble the Software; make derivative works based on the Software; publish or otherwise disseminate the Software. VTC, Inc., VTC Online University, and the Virtual Training Company site is owned and operated by VTC, Inc. as a corporation of record.
All materials on this site are the property of VTC unless otherwise specified. No material from these pages may be copied, reproduced, republished, downloaded, uploaded, posted, transmitted, or distributed in any way. Modification of the materials or use of the materials for any other purpose is a violation of U.S. copyright law and other proprietary rights. For purposes of this Agreement, the use of any such material on any other web site or networked computer environment is prohibited.

4. FEES: The rights granted under this Agreement are effective only upon payment of the subscription fees, which are strictly non-refundable other than as expressly provided herein. The term "monthly subscription" is defined as any 30 day period. The term "yearly subscription" is defined as one 365 day period. A yearly subscription ends on the same numerical date as it began (example July 28, 2004 to July 28, 2005).

The VTC Online University is access to every VTC training tutorial in our library. You pay a flat fee for access to these titles. You are billed according to your renewal selection below, and can renew monthly, yearly, or in any other increment offered. If you choose to be billed monthly, you will be billed every 30 days for the subscription until you request the subscription be cancelled. Our terms of service state that you must cancel a monthly subscription at least two business days before your renewal date. These two days give us enough time to ensure that you will not be charged again.

5. LIMITED WARRANTY: VTC warrants that the Software, if operated as directed, will substantially achieve the functionality described. VTC does not warrant, however, that Your use of the Software will be uninterrupted or that the operation of the Software will be error-free or secure. In addition, the security mechanisms implemented by the Software have inherent limitations, and You must determine that the Software sufficiently meets Your requirements. VTC also warrants that the media containing the Software, if provided by VTC, is free from defects in material from the date You acquired the Software. VTC's sole liability for any breach of this warranty shall be, in VTC's sole discretion: (i) to replace Your defective media or Software; or (ii) to advise You how to achieve substantially the same functionality with the Software as described; or (iii) if the above remedies are impracticable, to refund the subscription fee You paid for the Software. Only if You inform VTC of Your problem with the Software during the applicable subscription period will VTC be obligated to honor this warranty. VTC will use reasonable commercial efforts to repair, replace, advise, or refund pursuant to the foregoing warranty within thirty (30) days of being so notified. If any modifications are made to the Software by You during the warranty period; if the medium is subjected to accident, abuse, or improper use; or if You violate the terms of this Agreement, then this warranty shall immediately terminate. This warranty shall not apply if the Software is used on or in conjunction with hardware or software other than the unmodified version of hardware and software with which the Software was designed to be used as described.

THIS IS A LIMITED WARRANTY, AND IT IS THE ONLY WARRANTY MADE BY VTC OR ITS SUPPLIERS. VTC MAKES NO OTHER WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT OF THIRD PARTIES' RIGHTS. YOU MAY HAVE OTHER STATUTORY RIGHTS. HOWEVER, TO THE FULL EXTENT PERMITTED BY LAW, THE DURATION OF STATUTORILY REQUIRED WARRANTIES, IF ANY, SHALL BE LIMITED TO THE ABOVE LIMITED WARRANTY PERIOD. MOREOVER, IN NO EVENT WILL WARRANTIES PROVIDED BY LAW, IF ANY, APPLY UNLESS THEY ARE REQUIRED TO APPLY BY STATUTE NOTWITHSTANDING THEIR EXCLUSION BY CONTRACT. NO DEALER, AGENT, OR EMPLOYEE OF VTC IS AUTHORIZED TO MAKE ANY MODIFICATIONS, EXTENSIONS, OR ADDITIONS TO THIS LIMITED WARRANTY.

6. PROPRIETARY RIGHTS: VTC reserves all proprietary rights in and to the Software, is protected by copyright and other intellectual property laws and by international treaties. VTC, Inc.

Trademark Notice: VTC, Virtual Training Company, Inc., The VTC Logo, and VTC Online University, are trademarks of VTC, Inc. All other company and product names may be trademarks of their respective owners.
The information contained herein is subject to change without notice. Copyright © 1995 - 2005 VTC, Inc. All rights reserved.

7. TERMINATION: This Agreement shall automatically terminate if You fail to comply with the restrictions described herein. Your obligations to pay outstanding subscription fees shall survive any termination of this Agreement.

8. LIMITATION OF LIABILITY: UNDER NO CIRCUMSTANCES AND UNDER NO LEGAL THEORY, TORT, CONTRACT, OR OTHERWISE, SHALL VTC OR ITS SUPPLIERS OR RESELLERS BE LIABLE TO YOU OR ANY OTHER PERSON FOR ANY INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES OF ANY CHARACTER, INCLUDING WITHOUT LIMITATION, DAMAGES FOR LOSS OF GOODWILL, WORK STOPPAGE, COMPUTER FAILURE OR MALFUNCTION, OR ANY AND ALL OTHER COMMERCIAL DAMAGES OR LOSSES. IN NO EVENT WILL VTC BE LIABLE FOR ANY DAMAGES IN EXCESS OF THE AMOUNT VTC RECEIVED FROM YOU FOR A LICENSE TO THE SOFTWARE, EVEN IF VTC SHALL HAVE BEEN INFORMED OF THE POSSIBILITY OF SUCH
DAMAGES, OR FOR ANY CLAIM BY ANY OTHER PARTY. THIS LIMITATION OF LIABILITY SHALL NOT APPLY TO LIABILITY FOR DEATH OR PERSONAL INJURY RESULTING FROM VTC'S NEGLIGENCE TO THE EXTENT APPLICABLE LAW PROHIBITS SUCH LIMITATION. SOME JURISDICTIONS DO NOT ALLOW THE EXCLUSION OR LIMITATION OF INCIDENTAL OR CONSEQUENTIAL DAMAGES, SO THIS EXCLUSION AND LIMITATION MAY NOT APPLY TO YOU.

9. Links To Other Materials: Linked sites found at the VTC site are not under the control of VTC, and we are not responsible for the content of any linked site or any link contained in a linked site. VTC may change links based solely on our discretion, and we reserve the right to terminate any link or linking program at any time. VTC does not, by linking to sites, endorse companies or products to which it links and reserves the right to note as such on its web pages. If you decide to access any of the third party sites linked to this site, you do this entirely at your own risk.

Forums, and Chat are not always screened by VTC, and we are not responsible for the content of any public or open forum content at the site. VTC may change these public forums based solely on our discretion, and we reserve the right to terminate any forum at any time. VTC does not, by allowing these forums, endorse companies or products which may be mentioned in these forums, and reserves the right to note as such on its web pages. If you decide to access any of the public forums in this site, or linked to this site, you do this entirely at your own risk.

9. GOVERNING LAW & DISPUTE RESOLUTION: This Agreement is governed by Virginia law. All disputes between You and VTC shall be finally resolved through arbitration in Winchester, Virginia. This site is controlled by VTC from its offices within the United States of America. VTC makes no representation that materials in the site are appropriate or available for use in other locations, and access to them from territories where their content is illegal is prohibited. Those who choose to access this site from other locations do so on their own initiative and are responsible for compliance with applicable local laws. You may not use or export the Materials in violation of U.S. export laws and regulations. Any claim relating to the Materials shall be governed by the internal substantive laws of the Commonwealth of Virginia, USA.

VTC may revise these Terms at any time by updating this posting. You should visit this page from time to time to review the then-current Terms because they are binding on you. Certain provisions of these Terms may be superseded by expressly designated legal notices or terms located on particular pages at this Site.

If you have any questions regarding this policy, or your information specifically,
you may email us at:
admin@vtc.com.