A JavaScript Approach to FileMaker Custom Web Publishing

This is the beginning of a new, open source project to create a lightweight wrapper for FileMaker Custom Web Publishing designed for use in JavaScript applications.

Background: DayBack

The release of DayBack for FileMaker last month has started a very exciting time for us here at SeedCode! Bringing the Calendar to a new code base and seeing it successfully deployed in the real world has been nothing short of thrilling. We’ve recently added mobile support and are looking forward to the future enhancements of DayBack for Pro and Go.

However, now that we have this great JavaScript code base, it’s time to get going on DayBack for the browser, and starting with FileMaker Server as our first data source is the logical next step.

Assumptions

One of the goals for DayBack is to do as much of the data work as we can in JavaScript. This is based on two big assumptions, and seeing how these bare out will be an interesting part of this project:

  1. FileMaker Server is a powerful tool, and it can do a lot. However, this ability to multi-task tends to lead to deployments where it’s simply trying to do too much. On the web publishing side things like portals on target layouts, server side scripting, huge data sets, etc. often put a considerable load on the server. Can we architect DayBack to do this kind of work in the browser and therefore put a lighter load on our FileMaker Server?
  2. Supporting server side processes requires a different level and type of support than client side ones.  This is not just the case for FileMaker Server, but any server based application.  Supporting the server often requires working on a specific machine with specific issues that extend well beyond your app, web servers, permissions, program versions, etc. can all affect how things run.  By minimizing our server side footprint we hope to minimize the need for this kind of support.

fmxj.js

With these assumption in mind we’ve built a preliminary JavaScript library for building and posting queries to FileMaker Server and converting the results to JavaScript objects in a JSON format.  We have some working demos here.  We’ve also decided to make this part of the project open source (MIT License), so you can download (or fork) the library and demos from GitHub for free!

fmxj.js - working examples
fmxj.js – working examples

Here is what fmxj lets you accomplish:

    • Build complex queries and perform HTTP POSTs to your FileMaker Server.
    • Return FileMaker parent and child records as JavaScript Objects/JSON.
    • Create, edit and delete FileMaker records with JavaScript objects.
    • Filter and sort Javascript objects locally with complex criteria.
    • Query strings are created from JavaScript Objects and then sent as an HTTP POST to FileMaker’s XML Web Publishing Engine. An XML FMPXMLRESULT is returned and converted into JavaScript Objects/JSON by fmxj.
    • HTTP POSTS can be done directly to the FileMaker Server’s XML WPE or a simple PHP relay can be used to get around cross-domain issues and provide more authentication options.

As always, we love to take any opportunity we have to share our code, and I’m personally looking forward to keeping you posted on our progress.

Cheers!


Featured Posts

Follow Along

Stay up to date with the latest news & examples from SeedCode

12 Comments

  • Bob Rens

    Jason —

    Great work! Thinking beyond the curent project… any chance this will evolve into a newer, better way to automate migrating FM native screens and functionality into a web browser? (Yes, sounds like a more robust scalable version of IWP!?!) And, better yet… thinking Mobile First… dynamically reconfigure for desktop, mobile and smart phone applications (i.e., Android and iOS)? Just a thought!

    Bob

    • Jason Young

      Hi Bob,
      Thanks for the post and kind words!
      That’s not our plan for now. The idea here is to just get FileMaker data in a light weight way and integrate that with our JavaScript calendar DayBack.
      In fact, we’re almost going the other way, in that we’re bringing more JavaScript into FileMaker via the web viewer. As Steve SSH mentions above, bringing JavaScript into FM Pro and Go and running in it in the Web Viewer may be a better approach to getting parity between the browser and Pro/Go than going the other way with IWP or WebDirect. Indeed, we’re seeing more and more WebViewer based solutions in both FileMaker custom and product solutions, so it will be interesting to see how this plays out as WD gets faster vs. FM devs getting more comfortable with JavaScript.
      Let me know if that makes sense or if you’ve got any other questions.
      Cheers!

  • Jason, still loving this, but (gasp!) thinking over wider implications a bit more. So… a couple of new questions:

    – Have you explored how this performs at scale? I’m assuming performance will basically be gated by the XML API. Does that sound right to you?

    – Do you envision using fmxj.js on public web pages (with the scale & load issues that could bring), or do you see this as being targeted to Web Viewers (and perhaps browsers limited to more of a typical FileMaker workgroup-sized scale)?

    • Jason Young

      Hi Brian,
      Right, the XML Gateway is still the only way in. (PHP API is just an XML wrapper too). We’re finding that using our PHP relay is probably going to be the most practical deployment, but that too, just does a cURL to the XML Gateway.
      Our purpose is definitely the latter, in that DayBack will have subscribers that will connect to their known FileMaker server(s) as one of their potential data sources, and these would be people in that FM workgroup already.
      For public sites, I remain skeptical, but there are public sites out there, and I think the key to them staying up is keeping their server footprint light. No scripts, no portals, etc., and that’s what we’re going for here.
      I also think CWP performance is getting some residual benefits from WD, and I think we’ll continue to see that.
      Cheers!
      -Jason

  • John Renfrew

    I’ll have some of whatever is in your water… It’s obviously making you super switched on. Love how simple this appears to be to implement, masking the obvious power that it brings into easy reach.
    And without any complex installs or workrounds.
    Top marks and kudos to all.
    Now all I need is a project that requires me to learn how to best use this.

  • steve ssh

    Thank you for sharing your work. I believe that a library such as fmxj.js, combined with a client-side library such as AngularJS will be a powerful combination, and could be one of the best future methodologies for building CWP-type sites.

    Another advantage that I see is that it takes a step closer to writing chunks of UI code which can be shared between Pro (Desktop), Go, and a browser. I believe that, with the passing of time, more and more efficient techniques for writing this sort of UI code will be discovered and shared, and thus it will become easier and easier to write this type of UI code. I would even go as far as saying that this combination can open the door to deployment on non-iOS mobile devices in a native (albeit hybrid) app form.

    Thank you again for sharing and getting the ball rolling in this direction. As is evident from my comments above, I believe that it has much potential.

    -steve

    • seedcode

      “a step closer to writing chunks of UI code which can be shared between Pro (Desktop), Go, and a browser” indeed. Thanks for your support, Steve!

    • Thanks Steve!
      Sam Barnum from 360Works has an Angular library for FileMaker on Git Hub that I’ve been meaning to get into., so you might want to check that out as well. We’ve also heard some rumblings about some node.js adaptations which could be very exciting…stay tuned!

  • Jason, this is just… brilliant. The fmxj.js library looks powerful and really well thought out in JS terms. Kudos even more to you guys for choosing to release this to our community. Personally, I see this as a game changer: this comes at a perfect time, as we increasingly use JavaScript to do more and more “real” stuff with our FileMaker solutions. Thanks so much for this — and for all the work that obviously went into this. You guys rock!

    • seedcode

      THANK YOU, Brian! That means a lot.

Leave a Reply

Your email address will not be published. Required fields are marked *

Check out some of our other posts ...

New Week Views in DayBack for FileMaker

You can now expand DayBack’s week views to show two or three weeks at a time. We’ve been using this internally in beta mode for a few weeks, and it’s very helpful to see what’s coming up next week while navigating this week’s work. Find tips on how to work with these new views on the DayBack blog.

To-Do Lists in FileMaker – New in DayBack Calendar

Now create and manage FileMaker to-do lists directly from the Unscheduled Items sidebar in DayBack Calendar. Our latest extension brings to-do behavior to any FileMaker table. Like unscheduled items, this behavior is based on a new checkbox field in your table, so some or all of your records in the table can be treated as to-dos. Mark your to-do’s done as you complete them, or drag them into the calendar to schedule time to work on them. See it in action here: Customize Your To-Do Lists This extension was designed to be pretty a scaffold onto which you could build your own, more specific to-do behaviors by customizing the action itself or the FileMaker scripts tha manipulate events. Here are some ideas to get you started. Add To-Do Lists to Your FileMaker Calendar If you haven’t already enabled the unscheduled sidebar along DayBack’s right edge, you can learn how to turn that on here: unscheduled items in DayBack. Then, download the custom action and learn how to configure it here: To-Do Lists in DayBack Calendar.

Improved Resource Selection

We’ve made some big changes to how you filter and assign resources when editing events in DayBack. These changes will make it much easier to work with large numbers of resources, especially for folks assigning multiple resources to the same event. Watch a video of the new behaviors and learn more here: Adding Multiple Resources to an Item. If you haven’t looked at your resource field mapping in a while, here is how you set that up: Mapping the Resource Field in FileMaker. Please get in touch if you have any questions about this; we’re here to help.

Suggesting Appointment Slots

Show Available Slots that Match Multiple Criteria Schedulers often look for gaps in their schedules to find the open resources for each opportunity. But sometimes, gaps don’t tell the whole story. You may have invisible criteria like skill-matching, cleaning requirements, or multiple resources to schedule at once. Or you may be on the phone with an opportunity and must suggest available times as quickly as possible. In these cases, DayBack can suggest the best slots that match all of your requirements. Scheduling Criteria Are Often Invisible In the movie above, schedulers can see openings for the two technicians, but they can’t easily see if the required rooms and equipment are free at the same time. While DayBack can show different types of resources simultaneously, as the number of criteria increases, it can be hard for schedulers to see everything at once and still make good decisions. Our customers often have rules that constrain when an otherwise open slot can be scheduled. Here are some of the invisible criteria we’ve built out for customers: Because DayBack is highly scriptable, it can scrub open slots against a variety of criteria to render just the slots that fit all your requirements. When multiple slots match, DayBack can even rank them so you can present the most ideal slots to your clients first. You Have to *See* Slots in Context to Make the Best Decisions Many scheduling apps present possible appointments as a list of dates and times. Without showing more information about each slot, schedulers can book days too tightly, always suggest the same providers first, or create huge gaps in some provider’s schedules. Ranking slots can help, but we’ve found that highlighting ideal slots alongside existing appointments gives schedulers the information they need to make the best decisions. We’ve seen schedulers quickly offer to split appointments or to slightly change services when they see available slots in the context of other appointments, trainings, vacations, and breaks. Getting Started We customize the recommendation of slots for each deployment as part of DayBack’s implementation packages. Please get in touch if you think DayBack could make a big impact on your team.

COMPANY

FOLLOW ALONG

Stay up to date with the latest news & examples from SeedCode

© 2024 SeedCode, Inc.