Article Tags
Click or tap one of the article tags to filter down to a smaller selection.
- Accounts
- Add-ons
- AI
- Alerts
- Analysis
- APIs
- Apple Maps
- Auto-Enter
- Barcodes
- Base64
- BaseElements Plugin
- bBox
- Breadcrumbs
- Button Bars
- Caching
- Calculations
- Calendars
- Card Windows
- Charting
- Checkboxes
- Code Editing
- Code testing
- Coding
- Color Picker
- Colors
- Conditional Formatting
- Containers
- Context Management
- Cropping
- Crypto
- CSV
- cURL
- Custom Functions
- Custom Menus
- Data API
- Data Capture
- Data processing
- Data structure
- Data Viewer
- Date Ranges
- Dates
- Debugging
- Deployment
- Developer Tools
- Dialog Boxes
- Docker
- Drag-n-Drop
- Drop-down List
- Dropbox
- Duplicates
- Duplicating records
- Encryption
- Error handling
- Events
- Excel
- ExecuteSQL
- Exporting
- External Authentication
- External Files
- Field Formatting
- Field Storage
- Fields
- File IO
- File Management
- File Sharing
- FileMaker Go
- FileMaker Server
- FileMaker Settings
- Filtering
- Find & Replace
- Find Mode
- Found Sets
- Functions
- Fundamentals
- Global Fields
- Global Variables
- Google Forms
- Google Maps
- Google Services
- Graphics
- Grid
- Grouping
- Hierarchies
- Highlighting
- Icons
- Images
- Importing
- Indicators
- Inspector palette
- iOS
- Java/Groovy
- JavaScript
- Join Tables
- JSON
- Key fields
- Layout Design
- Layout Mode
- Layout Parts
- List function
- Logging
- Looping
- Mapping
- Marking Records
- Media Storage
- Menus
- Merge fields
- Messaging
- Microsoft Surface
- Mobile design
- MonkeyBread plug-in
- Multi-key fields
- Multi-option fields
- Naming Conventions
- Navigation
- New Release
- Node-RED
- Notifications
- Oauth
- Object management
- OCR
- OnGestureTap
- OnLayoutKeystroke
- OnObjectKeystroke
- Parsing HTML
- Perform Script on Server
- Performance
- Permissions
- Photo manipulation
- Pickers
- Pivot tables
- Pop-ups
- Popovers
- Portals
- Preferences
- Printing
- Privilege sets
- Product review
- Productivity
- Progress Bars
- PSOS
- Python
- Quick Find
- Record Locking
- Regex
- Relationship Graph
- Reporting
- REST
- Sankey
- Schema
- Script Parameters
- Script Triggers
- Scripting
- ScriptMaster
- SDK
- Searching
- Security
- Separation Model
- Set Variable
- Settings
- Shortcuts
- Sliders
- Snapshot Links
- Sorting
- Spelling
- Spreadsheets
- Startup
- Summary Fields
- SVG
- Syntax
- Syntax Highlighting
- Tab Controls
- Table View
- Tagging
- Terminology
- Text Parsing
- Themes
- Time fields
- Time Savings
- Tips
- Tools
- Transactions
- Tricks
- Twilio
- UI
- Updating
- User Interface
- Validations
- Value Lists
- vCalendar
- Virtual list
- Web Forms
- Web Scraping
- Web Services
- Web Viewers
- Webhooks
- Windows
- XML
Our Library of Videos
Because I've added history features to the My Invoicer solution, I decided to add one more video to the mix about using a History table. The concept behind the whole approach is to simply use a dedicated table which will track pretty much everything a user does to any data in the database - provided you account for such actions. This isn't exactly audit logging. It's another dimensions to knowing who is doing what in the database.
Using a History table is an extension to using a Sessions table, wherein with sessions you're tracking what a user does between the times they login and logout. Add audit logging to using a history table, and you have an extremely robust tracking and logging system.
There are many ways to approach data history and tracking. In my solution, I've opted to use the History table as the primary place where users interact with data. With the addition of Script Triggers in FileMaker 10, it's certainly possible to achieve history tracking using triggers on events such as OnLayoutLoad. This means you don't have to edit data through a relationship, such as is done in the My Invoicer file. However, there may be some advantages to taking this approach. Ultimately, no matter how you accomplish it technically, the goal is to maintain the history of what is done to the data in the database. A history table helps you accomplish this.
Portal filtering is simply one of the many tools to be used when you wish to provide an easy path of data access to someone looking for that data. Typically named Clairvoyance or Type Ahead, it's the familiar feature of staring to type and having a larger list of results narrow down based on the addition of new characters. As you type, you find what you're looking for.
While the feature has been possible in earlier versions of FileMaker, via the use of Script Triggering plug-ins, it's now an even more appealing feature with FileMaker 10's built-in Script Triggers.
In this video, I walk through the very detailed specifics of what makes portal filtering work and how you can create/use a reusable script when supporting this feature in multiple places within your FileMaker database.
Coding in FileMaker can become like a drug. If you think it can be done, you may be tempted to create it. However, there are a few times when you simply shouldn't. When technology exists, which you can leverage, it's often much faster (and better tested) to go outside of FileMaker.
In this video I showcase exactly how easy it is to implement a Text-to-HTML conversion tool using a very popular method named Markdown. If you, or your users, have ANY need to generate HTML - and do so easily - then this video and file will have what you need.
Using Markdown, you can quickly create valid HTML from much more human-readable text. If you know nothing about Markdown and how it might benefit you, then make sure to watch this video and learn from the technique file!
Even the most simple of objectives can often be optimized. It's the fun of making code smaller, more readable, more efficient that drives the developer spirit. Even if you don't consider yourself a developer, the lessons in this video will help guide your decisions when implementing features into your database.
This video showcases the breakdown of one simple feature, double-clicking. It does this using an optimized custom function. The result is a more flexible solution with more efficient code - which could actually be optimized even more than presented!
If you simply need double-clicking features in your FileMaker database then steal the custom function in the attached file. If you want to learn a valuable lesson in FileMaker development, then watch the video!
There are certain techniques in FileMaker which may not be immediately usable in your day-to-day work. However, simply knowing about the possibilities expands your mental toolbox - making you a better developer. You're always more equipped when you know both the weaknesses and advantages to the software you're using.
In this FileMaker video, I showcase a technique I'm calling Script Dispatchers. This is a concept where you can centralize code for easier solution management and better documentation. It could also be called a Layout Dispatcher, as the main functionality depends on a dedicated area within your layout.
Watch this video to see how you can access a wide range of script triggers and how you might employ this technique is some of your own solutions.
Script Triggers now allow for all kinds of solution logic based on simple user actions. If the user changes tabs, switches layouts or enters into a field, you can now trigger a script.
Beyond these simple situations, you can also watch for any time a user hits any key on the keyboard - aside from fkeys and specialty keys on custom keyboards. This invokes a mind-opening realization, but some times it's hard to come up with ways to use these new features.
Well, how about a simple spelling fixer. Not a spelling checker. An actual script that will fix (or change) a word as the user types! For any area where industry specific words are used, think medical and legal fields, you can ensure that these words are spelled correctly. This can now be done with FileMaker 10 and the technique file associated to this video!
Knowing how to loop through records in FileMaker helps with some of your data processing tasks. Knowing how to loop through a portal will help with the occasional odd technique. Knowing how to use a data loop is critical if you want your FileMaker solution to be as efficient as possible.
In this video, I showcase a simple data loop which performs syntax highlighting on some code in a text field. Even if you don't need syntax highlighting for code, then knowing how to use a data loop is what you need to know.
If you've not used many data loops in your solutions then this video will get you started right away!
Revealing the current state of your interface is of great benefit to users of your solutions. Features such as highlighting selected portal rows provide an instant indication of what is selected or where the user is.
When it comes to supporting unique rows within multiple portals on the same layout, you need to find a way to track each portal independently and know which record is selected within each portal.
Fortunately, through the power of named layout objects, some conditional formatting and a special utility script, you can accomplish this goal.
Watch this video for a great understanding of how to Highlight Portal Rows within your FileMaker solutions!
Updating your FileMaker interface can seem like an overwhelming task if you have hundreds of layouts. However, if you simply start with one layout, it provides the motivation to move on to the others.
The key here, is that the process may help you discover areas where you can optimize or repurpose your interface. Following a few simple rules may help you end up with a much more usable interface.
In this video, I walk through a 2 hour interface expedition where I used a publicly available demo file that comes with the ScriptMaster plug-in, and show you how I converted it to an updated look.
Argggggg!" you exclaim, as you realize you accidentally deleted a record because you were working on live data,
Ok, so, maybe it's never happened to you personally, but it may happen to any user account which can delete records in your database. So what's the best answer. Well, the best answer is to have a full audit trail/log in each solution you create. However, this isn't always the easiest to implement.
Instead, take 10 minutes (or less) and have a great solution for any account which should be allowed to [supposedly] delete records. The goal is not necessarily to eliminate the data from the database, it may be to simply make it so it doesn't apply. Because keeping a historical record is something that always comes in handy!