Keep Your Classes Clean
Published 19 years, 9 months past
See, that’s why presentational class names are such a bad idea.
See, that’s why presentational class names are such a bad idea.
So I upgraded to WordPress 1.5 over the weekend. Unfortunately, the “famous 5-minute installation” was, for me, about two orders of magnitude longer. This is not really the fault of WordPress or its crafters: my site is a fairly unusual case. I had pretty heavily modified the templates in WordPress 1.2 by changing the markup, rearranging PHP, that sort of thing, so I had to make sure the upgrade wouldn’t wreck the site. I was also using a number of plugins, many of which I’d written, and I wanted to be sure none of them would get broken.
At first I was planning to modify the WP 1.5 files directly, but then I realized that with the new Themes feature in WordPress, I could convert my markup into a new, separate theme. That took me a while, as I was learning the new structure of WP and figuring out what pieces of my markup needed to go where. Had I never messed around with the original WP markup, I could’ve skipped this step entirely, and saved myself a few hours of work. But then I wouldn’t understand the WP internals as well as I do now.
This thematic conversion was, it is to be expected, a one-time investment. From here on out, I can twiddle with stuff in the theme files, and not touch the WP core. This is a vast improvement over 1.2, and illustrates why themes are a huge win for power users as well as novices. Whether you want to just install and start blogging, or you feel like completely redoing the markup to suit your own twisted ends, WP’s themes will make your life much easier. It will also make it a lot easier to upgrade in the future. I used to fear upgrades because of all the hacking I’d done. Not any more.
Once I’d upgraded the core WP files, it was time to find out what it would take to upgrade my plugins. Basically, very little. I had some magic-quotes routines that had become redundant and needed to be stripped out. That was pretty much all that needed to be done.
However, thanks to new features in WP 1.5, it’s possible to greatly improve the way plugins operate and to very easily extend WP’s feature set entirely from a plugin (once you fix a bug discovered last week). Take WP-Gatekeeper, for example. In WP 1.2, installing Gatekeeper meant installing a plugin file and activating it, adding a file to the wp-admin directory, and modifying two WP core files as well as the comment template(s). Not exactly plug-n-play, which has probably limited its appeal to many WP users.
In WP 1.5, though, it’s possible to add administration pages dynamically—no files have to be edited—and to attach actions to comment form processing. So even at this stage of its overhaul, my development copy of Gatekeeper requires only the installation/activation of a plugin and editing of the comment template. By the time I’m done, it should require only installing and activating the plugin, with no need to edit any files.
Awesome.
All in all, despite the fact that it took so me long to line up all the pieces, I’m really glad to have upgraded to 1.5. I suspect I’ve only scratched the surface of what it has to offer, but what I’ve seen so far has been impressive. The combination of theme organization and plugin power makes this a much more modular, extensible, robust system. In 1.2, I felt like I was bending and rearranging a basic system to meet my specific needs; in 1.5, I feel like I’m working within an environment that has everything I need to do anything I want.
That’s why I’ve changed the site footer, which used to say I was using a copy of WP that I’d “hacked like it was attacking my family”. That’s no longer the case. Sure, I’ve added a number of home-brewed plugins (most of which are freely available) to enhance various things, and yes, I’ve created my own templates. But that stuff is all out of the core files and into separate packages, as it should be, while the core of WP is basically untouched.
Of course, I have a few quibbles here and there, as I do with just about any system I use (I’m a relentless customizer). The Dashboard doesn’t really do a whole lot for me as it stands, and I have some things I’d like to change in both the advanced post-editing interface and the plugin management page. This time around, though, I’m going to offer my changes as contributions to the WP code base, to be accepted or rejected as the developers see fit.
I doff my cap and bow in gratitude toward the WordPress team, and all the members of the WordPress community who have helped it grow and improve. A good tool is now a great tool, and I can only imagine where it will go from here.
Since Dave recently shared his upcoming conference schedule, I feel strangely motivated to do the same with my schedule. Memetic infection or just a case of “me too, me too!”? You decide.
Search Engine Strategies New York — I’ll be appearing on the panel “CSS Myths, Mistakes, & Reality” with Shari Thurow and Matt Bailey, as well as representatives of Yahoo! and Google. My role is to quickly explain the benefits of standards to an audience that may have ltitle to no knowledge of said benefits. The session will be 90 minutes, to provide plenty of Q&A time.
SXSW Interactive — I have three scheduled appearances in Austin, none of which have anything to do with CSS. The first is Emergent Semantics, a look at how to add semantic information to the Web today using already-available features of XHTML. The second is the panel Where Are the Women of Web Design?, an exploration of why there are so few female “leaders” in the Web design space, and how we might encourage more. Last, I’ll be one of the performers at Vox Nox, a New Riders event that features several authors performing pieces that aren’t technology-related. It will unfortuantely overlap a bit with 20×2, but not too badly.
The SXSW folks have also scheduled me to do two book signings, one on Sunday and the other Monday. If you’re going to be at the conference, bring a book to sign, or buy one there and get it signed. Just think—the signature alone will add at least a dime to the book’s worth, although the personalized inscription will knock it back off. That’s how it goes.
NOTACON 2 — held right here in fabulous Cleveland, Ohio, I’ll be giving two talks. One will be The Construction of S5; or, How I Learned to Stop Worrying and Love the DOM, about the evolution of S5, looking at various design decisions and the joy of DOM scripting. The other talk is Humanely Wielding a Clue By Four: Reflections on Managing a Massive Mailing List, an overview of what I’ve learned as List Chaperone for css-discuss, and what I think makes a good community manager.
WWW 2005 — and away I go to Chiba, Japan! For the conference, I’ll be presenting a half-day tutorial on standards-oriented design trends and techniques. I may also be presenting a poster, if it’s accepted by the poster committee, but I won’t know for a few weeks. I’m also planning to speak at the Tokyo PC Users Group, and am still scouting for consulting opportunities while in Japan. If you’re interested, please let me know!
Looking further into the future, I’m currently scheduled to speak at conferences in September and October. I’ll have details on those as the time draws closer. You can stay up to date with my public speaking schedule over at Complex Spiral Consulting, and yes, I really should turn it into an RSS feed. Some day…
A recent post by Ferrett about sneaky marketing via faux-stained envelopes reminded me I had a similar trick envelope sitting around to be scanned and posted. See that faint impression of a slightly askew credit card on the right half of the envelope? It looks just like the envelope got run through a rubber-wheel sorting mechanism, or maybe dropped and run over with a cart before being picked up, and the credit card being shadowed with dirt or something, right? There’s no card in the envelope. Inside this bit of chicanery is a “Pre-Approved Acceptance Certificate” that will let me transfer balances to a whole new card that they’d be just too darned happy to send me. Also a Fee and Rate Information pamphlet. That’s it—all paper. That faint card shadow is a bit of graphic design, nothing more.
Oh, they’re good: too clever by half. Especially since, having seen this trick, I’m less inclined to do business with these jokers in the future. And I’d like to point out that the jokers in question are not Visa, except by indirection. The presence of their logo in the upper left corner implies that they sent it, but they didn’t. It’s just an offer for a Visa card through Bank of America.
I’ve actually gotten a few more nearly identical envelopes by now, so the trick doesn’t work quite as well; all I have to do is flex the envelope to tell if there’s a card in there or not, which I actually do with all envelopes I’m preparing to throw away. But what really twists my grin is the corporate branding in the masthead of the enclosed letter exhorting me to take advantage of the limited-time no-hassle offer that they did their level best to trick me into reading: “Bank of America — Higher Standards”.
Um… maybe not.
Last July, I posted about how I got my Netgear MR814v2 to talk to my Airport Extreme laptop. The fix involved setting “Universal Plug ‘n’ Play” preferences.
Since then, I’ve gotten occasional e-mail messages from people thanking me for publishing the solution, and that neither Netgear nor Apple seem to know anything about this problem. I got one just today, and thought it was probably time for a follow-up post.
The fix I described isn’t a panacea, I’ve found; I still occasionally find the laptop knocked back to its self-assigned IP address. This behavior seems to revolve around hard sleep/wake events, and iChat might be implicated too. My father has a Netgear 802.11g wireless router and it’s totally smooth for him using an 802.11b PowerBook, but whenever I visit with my Airport Extreme PowerBook the router starts kicking us both off on an infrequent basis.
I’ve found one of two things will fix my router when it ceases talking to the laptop. One is to unplug and replug the router; the thing comes back up in about a second and it always sees the laptop again. The other is to log into the router from a wired computer, go to the UPnP page, and hit “Apply”. I don’t have to change any setting, just hit “Apply”. That fixes the problem too. I do the latter when I’m in my office with my wired G4, and the former when I’m downstairs closer to the router.
Either way, I’m thinking about replacing my 802.11b router with an 802.11g router so I can take advantage of the Extreme access, and I’m thinking the replacement won’t be a Netgear product. Anyone have recommendations for a good Airport Extreme compatible wireless/wired combo router (I need to plug in two CAT5-bound computers) besides an Airport Base Station?
So I recently got my hands on a copy of Photoshop CS—yes, a legal copy—and have been playing with it over the past few days. Here’s the thing: in my old Classic install of Photoshop 5.5, I had Extensis’ PhotoBars installed and it was basically like a slice of nerdvana. Every function I commonly used was right there, ready for action, not hiding three levels deep in whatever menu Adobe saw fit to bury it. Now if I want to transform a layer or switch color modes or resize an image, I have to go hunting. It’s annoying, it’s time-wasting, and it shouldn’t be necessary. Even if I trained myself to know exactly where every option lay in every menu, I’d still be slower than I was with PhotoBars, which offered me a fully customizable bar that gave one-click access to just about anything I wanted.
I found a single page regarding getting PhotoBars to work in Photoshop CS, but unfortunately it seems to be Windows-centric (given that the self-extracting demo is a .exe file). Either way, it starts out with “install PhotoBars”, which I tried to do and got nowhere. I then tried copying my Extensis stuff over from my old Photoshop install to the new one, and when I launched CS it cheerfully ignored all the new plugins I’d dropped into its folder structure.
And I should note that it’s entirely possible that CS has something equivalent built in, and I haven’t found it yet despite a look through the manual. If I’m being blind, point me in the right direction. If there’s third-party software that does this job, point me toward it. In any case, I really, really want PhotoBars back, or at least something with equivalent power and customization. Help!
Update: here’s an illustration of what I’m talking about…
The visual design of meyerweb turned a year old on February 1. As a little celebration, I’ve rolled out an update to the design. In the past, I’ve thrown out entire designs for completely new ones, but not this time around. This time, the changes are more of an incremental advance; or, if you prefer, a mutation of the previous design. After all, the basic layout is the same as before. I simply opened it up, allowing the various components more breathing room, and cleared away some of the clutter that had built up, such as the various “RSS 2.0” buttons. (So how does one now get the feeds? I’ll explain that in just a minute.)
There’s more to this than just a simple evolution, I admit. The first major change is the addition of navigation links across the top of each page. For some time now, a lot of the material that people come here to find was buried, difficult to find unless you knew where you were going, or else on what terms to search. By pointing directly to the topic areas I think will most interest visitors, I believe the site is now much easier to use.
The second major change is the layout of “metainformation” for each post (and comments on posts). In this area, I was heavily influenced by Khoi Vinh’s Subtraction 7.0, and I definitely owe him a debt of gratitude and inspiration. As will be evident from even a casual comparison of the two sites, I took a general design idea Khoi uses and adapted it to my particular situation. I think it works rather well.
The third notable change is a feature addition that I’ve been planning to add for a couple of months now. New to the site is a Syndication Feeds page which brings together (dare I say it aggregates?) all of meyerweb’s RSS feeds. The real step forward here is the debut of two new “Thoughts From Eric” feeds, including a feed of just technical posts and a feed of just personal posts. Now all of you who just come here for the technical stuff, and couldn’t care less about the person behind the site, can restrict your feed to screen out the worthless drivel. Similarly, those of you who know me personally but don’t understand the eye-glazing technical stuff can filter out the confusing nerdity.
Even better, each of the three “Thoughts From Eric” feeds (including the traditional “show me everything!” feed) comes in one of two flavors: summary or full content. At long last, I’ll find out if providing full-content feeds drives my bandwidth consumption up, or eases it down.
I’ve also established a new Redesign Watch feed, which is something I know will be of interest to many visitors.
I made other small refinements throughout, and odds are I’ll continue to tinker for a little while. Overall, though, I feel I met my goal of making meyerweb a more friendly site to visit, and a more feature-rich environment. Explore, and enjoy.
One of my long-time favorite places to eat is Yours Truly, which is a local chain of sorts—well, to be honest, they’re more of a local institution in seven locations—and whose Web site lends serious support to my theory that site quality is inversely proportional to food quality. They also have free WiFi at the location nearest us, not that I ever happen to have my laptop along when I’m there. But there’s always the possibility of using it.
In a menu full of good things, one of my favorites is their Notso™ Fries (“They’re notso common!”). To make a plate of Notso™ Fries, you first pile up some cottage fries, which are those little round crinkle-cut jobbies. To the fry pile, you then add a whole bunch of cheese. Then crumbled bacon, and I think more cheese. The whole plate is then broiled until the cheese is golden, and just before serving you plop on a generous dollop o’ sour cream.
It’s like a heart attack on a plate.
I had long thought that this wonderful dish represented, in some sense, the apex of cholesterolicious cooking, but this morning I discovered that I was wrong, that the fine folks at Yours Truly had gone themselves one better and given us…
The Notso™ Omelet.
Substitute hashbrowns for the cottage fries but keep everything else the same, stuff the result into a three-egg omelet, and put the sour cream on top.
Oh yeah.