An early viewer asked some questions about the art I use on my site, so I thought I would put together a page of Q&A about the site and the materials on it.
Who are you, now?
I'm Mike Kupietz. You can be forgiven for not knowing who I am. Although I do have to admit I privately hoped I'd make more of a splash. I'm a musician, artist, and by day a FileMaker consultant and web developer based, strictly due to an accident of fate, in San Francisco.
Where did you get _____ image? / Did you do all this art?
Mostly all the images on this site are my own art. There are a few public domain images on this site. As of this writing the images I didn't create are:
- the poo emoji on the BS Detector post
- Cezanne's "House with Red Roof", which I used a detail of as the cover of my perpetually under-construction album "Five Themes In Uncertain Times" as a symbolic representation that I'll try to get around to explaining if I ever get that album finished and released
- The ornate "K" stamp logo (in the background of the header and used as a default featured image for posts without a custom one), which is a logo I've used for many years, from an actual rubber stamp that I bought in the stamp store in Northgate Mall in Seattle in probably 1995. It's originally from the decorative typeface "Cloister Initials" created in 1918 by renowned typographer Frederic W. Goudy, and nowadays available online as LTC Goudy Initials, which is (sometimes) used for the ostentatious drop caps at the beginning of each post page of the site. (Goudy was also the designer of the dreadfully overused Copperplate Gothic, which will be familiar to anyone who was anywhere in the 1990s.)
- Also, when reviewing equipment or apps, I may include a screenshot or image from the author's site, as I did with my post about the Bento Box synthesizer... I hope this is alright.
- This list may not be exhaustive. There may be others here and there as I work on the site.
All other images are by me. As of this writing, AI generative art has been a recent fascination, so many of the images were created that way, but a few older ones, particularly album covers of older pieces and recordings, are my own photography, photoshop manipulations, or done in iOS apps such as Sketch Club, Art Set, or Snapseed. For a while I was doing a lot of abstracts in Sketch Club and then punching them up using Google's original Deep Dream AI image enhancer.
The written and audio content of this site is all yours?
All mine. Except, where music is clearly marked as cover songs, in which case it's my original arrangement of somebody else's music.
Did you code this whole site yourself, or use a canned WordPress theme?
This site runs on WordPress and is built on my own every extensive code customizations to the free Sinatra theme. If you click that "Sinatra" link and hit the "preview" button to look at their demo, anything you see on this site's design that isn't in their demo, I wrote myself in PHP. It was not fun, I can tell you that. I hate PHP.
But, I'm a code cowboy, and distrusting of other software developers, so anything not super-complicated, I'd prefer to code myself than use a plugin for.
How about those awesome menus up top? Did you write the code that creates those? Surely you just get those from a canned plugin, right?
No such luck. What I did was take the free version of the Hierarchical HTML Sitemap plugin and customize the PHP code of it almost beyond recognition to get it to generate usable menus in the way I wanted. On my list of things to do is a post showing the customized plugin code that creates the menus.
Come on. I'm a geek. Give me the full technical details of how the menus work.
The menus are built on-the-fly by analyzing WordPress's built-in hierarchical post category feature, it reads the tree of post categories and and subcategories and builds the menu directly from it. There is an invisible topmost category, "MenuCategories", which contains the categories "About / Meta", "Writing", "Visual Arts", etc., which are displayed as the menu titles, then recursive levels of submenus are built from the subcategories and posts each category contains. The entire process is very painful.
The modified Hierarchical HTML Sitemap output is called by a WordPress shortcode, which I found some code on StackOverflow to allow me to use shortcodes as menus. So, internally, the entire menu structure of this site is just one single custom menu entry, with a description similar to '[sitemap startcat="MenuCategories"]'.
What fonts do you use on this site?
I was very gratified when someone complimented my display font on this site, because I attacked choosing that font with brutal, neurotic, perfectionistic determination. When I first had the idea of this site, I knew what I wanted the "KUPIETZ|ARTS+CODE" to look like, right down to the font, and I spent a long time going through Google Fonts trying to find it. Ultimately I couldn't find an exact match to what I had in my head, but the web font Red Hat Display came closest.
Smaller headings and body text are my old standby Open Sans, which is probably my favorite body typeface of all time, possibly excepting whatever they used in that '80s paperback edition of "Dream Park" by Larry Niven, which I've never been able to find a digital recreation of. (Yes, design geeks, Sunset Serial Regular is very similar. I know that. You think I don't know that?)
What WordPress plugins do you use?
Here's an auto-generated PHP dump of plugins which are active right now. Some of them might not be in use on the site even though they're active. A few have been blocked from appearing in this list so as not to give away my site security measures.
- Site Inspector - Inspect active themes, post types, shortcodes, APIs, CDNs, templates, and more—visually.
- Advanced TinyMCE Configuration - Set advanced TinyMCE options for the classic block and classic editor.
- Classic Editor - Enables the WordPress classic editor and the old-style Edit Post screen with TinyMCE, Meta Boxes, etc. Supports the older plugins that extend this screen.
- Code Profiler - A profiler to measure the performance of your WordPress plugins and themes.
- Custom Taxonomy Order - Allows for the ordering of categories and custom taxonomy terms through a simple drag-and-drop interface.
- Disable Comments by click5 - Disable comments on your website and protect yourself from spammers.
- embed-githubin - Shortcode for a box with a github project.
- Freesoul Deactivate Plugins - Disable plugins on specific pages for performance improvement and support in problem-solving even when you have many plugins.
- Gallery Lightbox Lite - Displays your images gallery into the awesome and responsive lightbox slider with very easy
- Kupietools AAA Help Tab - Explains what th' heck all those bells and whistles are
- KupieTools Add Class To Link - Adds a custom class to all external links in content except for image links.
- KupieTools Add Preview To Details Elements - Adds excerpt summarizing contents of closed Details disclosure elements.
- KupieTools Admin Gallery Download - Adds a download link after galleries for administrators
- KupieTools Always Redirect To Permalink - Always give a 301 redirect to the permalink if loaded at some other URL.
- KupieTools Caching Toolkit - Functions for developers to implement Wordpress function caching for performance.
- Kupietools CLI Opener - Opens the Expert Mode CLI navigation
- KupieTools Custom WordPress Settings - My custom non-theme-specific WordPress code and settings.
- KupieTools Debug Log Manager - Simple debug logging controls for WordPress that integrates with KupieTools admin section
- Kupietools Debuggery Toolkit - My custom debugging helper functions.
- KupieTools Draggable Elements - Make page elements draggable, with optional movement constraints.
- KupieTools Editor Code Folding - Adds code folding disclosure triangles to Plugin File Editor and Theme File Editor admin screens.
- KupieTools Editor Developer Log - Bells and whistles for theme and plugin editor pages.
- KupieTools Editor File Manager - Add Create New, Rename, and Download file options to Plugin File Editor and Theme File Editor admin screens.
- KupieTools Embed Page - Adding embeddable pages with /embed/ or ?embed URLs.
- KupieTools Embed YouTube Playlist - adds a ytembed shortcode to display the videos in a YouTube playlist individual on a WordPress page.
- KupieTools Front End Classic Editor - Adds the WordPress editor directly on the front end of posts
- KupieTools Function timer - Provides a utility function allowing you to record function execution time to debug.log
- KupieTools GitHub Plugin Pusher - Adds a "Push to GitHub" button to the plugin editor page for repositories
- Kupietools Hire Mike - Adds a floating div in the bottom-right corner of the screen with hover effects and a clickable link.
- KupieTools Link Tweaks For SEO - Massage prettyurls, post paths, how links are inserted, etc..
- MK Lynx Mode - Forces logged-out view when mklynx parameter is present
- Kupietools Page Appearance Adjuster - Adds a control panel to adjust page brightness, contrast, and color temperature
- Kupietools Page Cache - Caches full pages as static HTML, saving time on subsequent loads of heavy pages.
- KupieTools Post 404 Avoider - Finds correct post for urls like domain.com/category/child-category/title when permalink scheme is domain.com/title
- KupieTools Reveal Hidden Named Anchors - Adds ability to automatically reveal named anchors even if hidden in disclosure elements. More to come, maybe.
- Kupietools Tab Creator - A framework for creating and managing a common tabbed interface for Kupietools plugins.
- KupieTools The Eyes Have It - It's watching you. Eyes on your WordPress page, watching your every move, watching, always watching. Built with the KTWP KupieTools WordPress Plugin Framework
- LiteSpeed Cache - High-performance page caching and site optimization from LiteSpeed
- Login No Captcha reCAPTCHA (Google) - Adds a Google CAPTCHA checkbox to the login, registration, and forgot password forms, thwarting automated hacking attempts
- MK Custom Shortcodes - My custom shortcodes.
- MK debugging additions - Dump queued scripts into a comment.
- mk Hierarchical HTML Sitemap - MK modification of plugin. Generates menus from category hierarchies. Original description: Generates hierarchical HTML sitemap wich displays hierarchically sorted categories with posts links. You need add [htmlmap]shortcode at any page. It's working easy and fast. Super lightweight PHP code, without external CSS/JS files.
- MK Multi-column Tag Map - MK customized plugin, used to generate pages of movie reviews, fragrance reviews, etc. Original description: Multi-column Tag Map displays a columnized and alphabetical (English) listing of all tags used in your site similar to the index pages of a book.
- MK Sinatra Additions - My custom Sinatra theme code.
- Photonic Gallery & Lightbox for Flickr, SmugMug & Others - Extends the native gallery to support Flickr, SmugMug and Zenfolio. JS libraries like BaguetteBox, BigPicture, Gie Lightbox, LightGallery, PhotoSwipe, Spotlight, Swipebox, Fancybox, Magnific, Colorbox, PrettyPhoto, Image Lightbox, Featherlight and Lightcase are supported. Photos are displayed in vanilla grids of thumbnails, or more fancy slideshows, or justified or masonry or random mosaic layouts. The plugin also extends all layout options to a regular WP gallery.
- Polar Mass Advanced IP Blocker - Automatically blocks malicious IP addresses through Cloudflare integration based on Wordfence failed login attempts.
- Post Type Switcher - A simple way to change a post's type in WordPress
- Preserve Code Formatting - Preserve formatting of code for display by preventing its modification by WordPress and other plugins while also retaining whitespace.
- Regenerate Thumbnails - Regenerate the thumbnails for one or more of your image uploads. Useful when changing their sizes or your theme.
- Related Posts for WordPress - Related Posts for WordPress, the best way to display related posts in WordPress.
- Search Regex - Adds search and replace functionality across posts, pages, comments, and meta-data, with full regular expression support
- Simple History - Plugin that logs various things that occur in WordPress and then presents those events in a very nice GUI.
- Simple Local Avatars - Adds an avatar upload field to user profiles. Generates requested sizes on demand, just like Gravatar! Simple and lightweight.
- System Dashboard - Centralized dashboard to monitor various WordPress components, stats and data, including the server.
- UpdraftPlus - Backup/Restore - Backup and restore: take backups locally, or backup to Amazon S3, Dropbox, Google Drive, Rackspace, (S)FTP, WebDAV & email, on automatic schedules.
- Yoast SEO - The first true all-in-one SEO solution for WordPress, including on-page content analysis, XML sitemaps and much more.
- WP Crontrol - Take control of the cron events on your WordPress website.
- WP Fail2Ban Redux - Records various WordPress events to your server's system log for integration with Fail2Ban.
- WP Last Modified Info - Ultimate Last Modified Plugin for WordPress with Gutenberg Block Integration. It is possible to use shortcodes to display last modified info anywhere on a WordPress site running 4.7 and beyond.
- Yoast Test Helper - Utility to provide testing features for Yoast plugins.
Wait a second, hold up. How did you get WordPress to cough up a live list of active plugins?
It's not hard. It's a little PHP function I wrote. I promise I will write a post about that. It's on my list.
I notice some of your image galleries work differently than WordPress's default galleries. Please tell me you didn't recode their entire built-in gallery function.
What do you take me for? Yeah, of course I did.
Well, I extensively modified it to do what I want, I didn't rewrite it 100% from scratch. But, yeah, things like having one caption stretch across multiple images, different numbers of images on each row, etc., WordPress's default gallery doesn't let you do those. Mine does. It was tricky, and another thing I'll make a post about at some point to explain how it all works.
I also had to make sure it still worked with the Gallery Lightbox plugin's functions, a little plugin for creating the interactive fullscreen gallery display when you click on an image in a gallery, which is simple and efficient and works very well but in no way expects some of the wierd kinds of stuff I throw at it. It was all a little bit of a pain.






 
	 
 