[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"project-7158":3},{"id":4,"name":5,"fullName":6,"owner":7,"repo":5,"description":8,"homepage":9,"htmlUrl":10,"language":11,"languages":10,"totalLinesOfCode":10,"stars":12,"forks":13,"watchers":14,"openIssues":15,"contributorsCount":16,"subscribersCount":16,"size":16,"stars1d":16,"stars7d":16,"stars30d":17,"stars90d":16,"forks30d":16,"starsTrendScore":16,"compositeScore":18,"rankGlobal":10,"rankLanguage":10,"license":19,"archived":20,"fork":20,"defaultBranch":21,"hasWiki":20,"hasPages":20,"topics":22,"createdAt":10,"pushedAt":10,"updatedAt":23,"readmeContent":24,"aiSummary":25,"trendingCount":16,"starSnapshotCount":16,"syncStatus":26,"lastSyncTime":27,"discoverSource":28},7158,"plaid","nickbutcher\u002Fplaid","nickbutcher","An Android app which provides design news & inspiration as well as being an example of implementing material design.","",null,"Kotlin",16193,3095,605,78,0,3,45,"Apache License 2.0",false,"main",[],"2026-06-12 02:01:35","# \\[ 🚧 Work in progress 👷‍♀️⛏👷🔧️👷🔧 🚧 \\] Plaid 2.0 \n\nRewriting Plaid using [Android Architecture Components](https:\u002F\u002Fdeveloper.android.com\u002Ftopic\u002Flibraries\u002Farchitecture\u002F), in Kotlin. \n\n👀 \"[Up for grabs](https:\u002F\u002Fgithub.com\u002Fnickbutcher\u002Fplaid\u002Fissues?q=is%3Aissue+is%3Aopen+label%3A%22Up+for+grabs+%F0%9F%A4%9A%22)\" issues – We're happy to [get your contributions](https:\u002F\u002Fgithub.com\u002Fnickbutcher\u002Fplaid\u002Fblob\u002Fmaster\u002FCONTRIBUTING.md#contributing-a-patch) on those!\n\n👍 Comments and new issues created are welcomed.\n\n🛑 We're currently not accepting external PRs that touch on the app's architecture.\n\n[![CircleCI](https:\u002F\u002Fcircleci.com\u002Fgh\u002Fandroid\u002Fplaid\u002Ftree\u002Fmaster.svg?style=shield)](https:\u002F\u002Fcircleci.com\u002Fgh\u002Fandroid\u002Fplaid\u002Ftree\u002Fmaster)\n\n### Background\n\nPlaid was written with one big goal: showcase material design in Android in a real application. While Plaid successfully achieved its goal, from an architecture point of view, it lacks all features that would make it a modular, scalable, testable and maintainable app: with UI logic in Android classes, no tests and only one module. \nPlaid represents a great real world app example: it provides a fairly complex set of functionalities, it has technical debt, it has features that have to be dealt with as APIs are being removed.\nAll of these problems are encountered by many projects in the Android community and therefore, make Plaid a suitable showcase for all the advantages that architecture components bring. \n\n#### More information\n\n* Read more:\n\n\t* [Restitching Plaid - Updating Plaid to modern app standards](https:\u002F\u002Fmedium.com\u002F@crafty\u002Frestitching-plaid-9ca5588d3b0a)\n\t* [A patchwork Plaid - Monolith to modularized app](https:\u002F\u002Fmedium.com\u002Fandroiddevelopers\u002Fa-patchwork-plaid-monolith-to-modularized-app-60235d9f212e)\n\t* [Cross-stitching Plaid and AndroidX](https:\u002F\u002Fmedium.com\u002Fandroiddevelopers\u002Fcross-stitching-plaid-and-androidx-7603a192348e)\n\t* [Dependency injection in a multi module project](https:\u002F\u002Fmedium.com\u002Fandroiddevelopers\u002Fdependency-injection-in-a-multi-module-project-1a09511c14b7)\n\n* Video Presentations:\n\n\t* [Shaping Your App's Architecture with Kotlin and Architecture Components by Florina](https:\u002F\u002Fyoutu.be\u002FSy6ZdgqrQp0) (Florina Muntenescu at KotlinConf 2018)\n\t* [Re-stitching Plaid with Kotlin](https:\u002F\u002Fyoutu.be\u002FNNWejxBORgc) (Florina Muntenescu at Android Dev Summit '18)\n\n### Goals\n* Migrate Plaid to Architecture Components. The refactoring will follow the architecture described in [Guide to App Architecture](https:\u002F\u002Fdeveloper.android.com\u002Fjetpack\u002Fdocs\u002Fguide).  \n* Convert to Kotlin, while migrating to Architecture Components.\n* Modularize the app using [dynamic feature modules](https:\u002F\u002Fdeveloper.android.com\u002Fguide\u002Fapp-bundle\u002F).\n* Showcase the extensibility of the architecture by adding an extra data source, once the migration is finished.\n\n### Non-Goals\nChanges to the styles, themes, icons, animations, transitions or any other UI elements that were the initial focus of Plaid, are outside the scope of this refactoring. \n\n### Android Studio IDE setup\n\nPlaid requires Android Studio version 3.6 or higher.\n\nPlaid uses [ktlint](https:\u002F\u002Fktlint.github.io\u002F) to enforce Kotlin coding styles.\nHere's how to configure it for use with Android Studio (instructions adapted\nfrom the ktlint [README](https:\u002F\u002Fgithub.com\u002Fshyiko\u002Fktlint\u002Fblob\u002Fmaster\u002FREADME.md)):\n\n- Close Android Studio if it's open\n- Download ktlint using these [installation instructions](https:\u002F\u002Fgithub.com\u002Fshyiko\u002Fktlint\u002Fblob\u002Fmaster\u002FREADME.md#installation)\n\n- Inside the project root directory run:\n\n  `.\u002Fktlint --apply-to-idea-project --android`\n\n- Remove ktlint if desired:\n\n  `rm ktlint`\n\n- Start Android Studio\n\n---\n\n# Plaid 1.0\n\n\u003Cimg src=\"screenshots\u002Fplaid_demo.gif\" width=\"300\" align=\"right\" hspace=\"20\">\n\n*Design news and inspiration.*\n\nPlaid is a showcase of [material design](https:\u002F\u002Fwww.google.com\u002Fdesign\u002Fspec\u002F) that we hope you will\nkeep installed. It pulls in news & inspiration from [Designer News](https:\u002F\u002Fwww.designernews.co\u002F),\n[Dribbble](https:\u002F\u002Fdribbble.com\u002F) & [Product Hunt](https:\u002F\u002Fwww.producthunt.com\u002F). It demonstrates\nthe use of\n[material principles](https:\u002F\u002Fwww.google.com\u002Fdesign\u002Fspec\u002Fmaterial-design\u002Fintroduction.html#introduction-principles)\nto create tactile, bold, understandable UIs.\n\n**[Install on Google Play (Beta Testing)](https:\u002F\u002Fplay.google.com\u002Fapps\u002Ftesting\u002Fio.plaidapp)**\n\n\n### Screenshots\n\n\n\u003Cimg src=\"screenshots\u002Fhome_grid_framed.png\" width=\"25%\" \u002F>\n\u003Cimg src=\"screenshots\u002Fpost_story_framed.png\" width=\"25%\" \u002F>\n\u003Cimg src=\"screenshots\u002Fdn_story_framed.png\" width=\"25%\" \u002F>\n\u003Cimg src=\"screenshots\u002Fdribbble_shot_framed.png\" width=\"25%\" \u002F>\n\n\n##### Non-Goals\nPlaid is a UI sample and seeks to demonstrate how to implement material design. To make this as clear as possible it explicitly does not attempt to:\n* Provide opinionated **architecture\u002Ftesting** advice; it utilizes vanilla Android components. For advice on this, I'd recommend [Blueprints](https:\u002F\u002Fgithub.com\u002Fgooglesamples\u002Fandroid-architecture).\n* Support **pre-Lollipop** devices. Doing so is entirely possible, but complicates things. For advice on doing this, see [this fork](https:\u002F\u002Fgithub.com\u002Fhzsweers\u002Fplaid\u002Ftree\u002Fz\u002Fmoarbackport).\n\n\n### License\n\n\n```\nCopyright 2015 Google LLC.\n\nLicensed to the Apache Software Foundation (ASF) under one or more contributor\nlicense agreements. See the NOTICE file distributed with this work for\nadditional information regarding copyright ownership. The ASF licenses this\nfile to you under the Apache License, Version 2.0 (the \"License\"); you may not\nuse this file except in compliance with the License. You may obtain a copy of\nthe License at\n\nhttp:\u002F\u002Fwww.apache.org\u002Flicenses\u002FLICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS, WITHOUT\nWARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the\nLicense for the specific language governing permissions and limitations under\nthe License.\n```\n","Plaid 是一个提供设计新闻与灵感的 Android 应用，同时也是一个实现 Material Design 的范例。该项目使用 Kotlin 语言重写，并采用了 Android 架构组件来提高模块化、可扩展性、可测试性和可维护性。它展示了如何将现有应用迁移到现代架构标准，特别适合于需要了解如何利用架构组件改进应用质量的开发者学习参考。此外，通过动态功能模块化等技术手段，Plaid 还示范了如何构建灵活且易于扩展的应用架构。",2,"2026-06-11 03:10:54","top_language"]