├── .env.testing ├── .github └── workflows │ └── testing.yml ├── LICENSE.txt ├── README.md ├── app ├── Http │ ├── Controllers │ │ ├── Controller.php │ │ ├── StyleguideBasicsController.php │ │ ├── StyleguideColorController.php │ │ ├── StyleguideController.php │ │ └── StyleguidePatternController.php │ └── Requests │ │ └── StyleguideColorPost.php ├── Nova │ ├── StyleguideBasics.php │ ├── StyleguideColor.php │ └── StyleguidePattern.php ├── Observers │ └── StyleguideColorObserver.php ├── Providers │ ├── StyleguideColorModelServiceProvider.php │ ├── StyleguideNovaTool.php │ └── StyleguideServiceProvider.php ├── StyleguideBasics.php ├── StyleguideColor.php ├── StyleguidePattern.php └── View │ └── Components │ └── Base.php ├── composer.json ├── composer.lock ├── database ├── factories │ ├── StyleguideBasicsFactory.php │ ├── StyleguideColorFactory.php │ └── StyleguidePatternFactory.php ├── migrations │ ├── 2020_07_07_201044_create_styleguide_patterns_table.php │ ├── 2020_07_09_171757_create_styleguide_colors_table.php │ └── 2020_07_11_145517_create_styleguide_basics_table.php └── seeds │ ├── StyleguideBasicsSeeder.php │ ├── StyleguideColorSeeder.php │ └── StyleguidePatternSeeder.php ├── mix-manifest.json ├── package-lock.json ├── package.json ├── public ├── css │ └── styleguide.css └── js │ ├── styleguide.js │ └── styleguide.js.map ├── resources ├── js │ └── styleguide.js ├── sass │ └── styleguide.scss └── views │ ├── basics │ ├── edit.blade.php │ └── list.blade.php │ ├── codemirror.blade.php │ ├── colors │ ├── create.blade.php │ ├── edit.blade.php │ └── list.blade.php │ ├── components │ ├── base-error.blade.php │ └── base.blade.php │ ├── index.blade.php │ ├── layout.blade.php │ ├── navigation.blade.php │ └── patterns │ ├── create.blade.php │ ├── edit.blade.php │ └── list.blade.php ├── routes └── routes.php └── webpack.mix.js /.env.testing: -------------------------------------------------------------------------------- 1 | APP_NAME=Laravel 2 | APP_ENV=testing 3 | APP_KEY=base64:5CpEFQ9UTR543dbJUsT3araoSSyxuN8NF92gCJJXpk8= 4 | APP_DEBUG=true 5 | APP_URL=http://localhost 6 | 7 | LOG_CHANNEL=stack 8 | 9 | DB_CONNECTION=sqlite 10 | DB_DATABASE=/Users/grayloon/Sites/laravel/blog/database/database.sqlite 11 | 12 | BROADCAST_DRIVER=log 13 | CACHE_DRIVER=array 14 | SESSION_DRIVER=array 15 | SESSION_LIFETIME=120 16 | QUEUE_DRIVER=sync 17 | 18 | MAIL_DRIVER=array 19 | -------------------------------------------------------------------------------- /.github/workflows/testing.yml: -------------------------------------------------------------------------------- 1 | name: build 2 | 3 | on: 4 | push: 5 | branches: 6 | - master 7 | pull_request_target: 8 | branches: 9 | - master 10 | types: [opened, reopened] 11 | 12 | jobs: 13 | laravel-tests: 14 | runs-on: ubuntu-latest 15 | 16 | steps: 17 | - name: Install host app 18 | run: composer create-project --prefer-dist laravel/laravel host 19 | 20 | - name: Checkout the package 21 | uses: actions/checkout@v2 22 | with: 23 | path: host/packages/xpersonas/laravel-styleguide 24 | 25 | - name: Verify package location 26 | working-directory: ./host 27 | run: ls -la packages/xpersonas 28 | 29 | - name: Copy .env 30 | run: php -r "file_exists('.env') || copy('.env.example', '.env');" 31 | 32 | - name: Create Database 33 | run: | 34 | mkdir -p database 35 | touch database/database.sqlite 36 | 37 | - name: Install Dependencies 38 | working-directory: ./host/packages/xpersonas/laravel-styleguide 39 | run: composer install -q --no-ansi --no-interaction --no-scripts --no-progress --prefer-dist 40 | 41 | - name: Execute tests (Unit and Feature tests) via PHPUnit 42 | env: 43 | DB_CONNECTION: sqlite 44 | DB_DATABASE: database/database.sqlite 45 | working-directory: ./host/packages/xpersonas/laravel-styleguide 46 | run: ./vendor/bin/phpunit --testdox 47 | 48 | - name: PHPCS Code Quality 49 | working-directory: ./host/packages/xpersonas/laravel-styleguide 50 | run: ./vendor/bin/phpcs --ignore=node_modules,vendor,tests,database,*.blade.php --standard=PSR2 --extensions=php . 51 | 52 | - uses: 8398a7/action-slack@v3 53 | with: 54 | status: ${{ job.status }} 55 | fields: repo,message,commit,author,action,eventName,ref,workflow,job,took # selectable (default: repo,message) 56 | env: 57 | GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} # optional 58 | SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }} # required 59 | if: always() # Pick up events even if the job fails or is canceled. 60 | -------------------------------------------------------------------------------- /LICENSE.txt: -------------------------------------------------------------------------------- 1 | GNU GENERAL PUBLIC LICENSE 2 | Version 3, 29 June 2007 3 | 4 | Copyright (C) 2007 Free Software Foundation, Inc. 5 | Everyone is permitted to copy and distribute verbatim copies 6 | of this license document, but changing it is not allowed. 7 | 8 | Preamble 9 | 10 | The GNU General Public License is a free, copyleft license for 11 | software and other kinds of works. 12 | 13 | The licenses for most software and other practical works are designed 14 | to take away your freedom to share and change the works. By contrast, 15 | the GNU General Public License is intended to guarantee your freedom to 16 | share and change all versions of a program--to make sure it remains free 17 | software for all its users. We, the Free Software Foundation, use the 18 | GNU General Public License for most of our software; it applies also to 19 | any other work released this way by its authors. You can apply it to 20 | your programs, too. 21 | 22 | When we speak of free software, we are referring to freedom, not 23 | price. Our General Public Licenses are designed to make sure that you 24 | have the freedom to distribute copies of free software (and charge for 25 | them if you wish), that you receive source code or can get it if you 26 | want it, that you can change the software or use pieces of it in new 27 | free programs, and that you know you can do these things. 28 | 29 | To protect your rights, we need to prevent others from denying you 30 | these rights or asking you to surrender the rights. Therefore, you have 31 | certain responsibilities if you distribute copies of the software, or if 32 | you modify it: responsibilities to respect the freedom of others. 33 | 34 | For example, if you distribute copies of such a program, whether 35 | gratis or for a fee, you must pass on to the recipients the same 36 | freedoms that you received. You must make sure that they, too, receive 37 | or can get the source code. And you must show them these terms so they 38 | know their rights. 39 | 40 | Developers that use the GNU GPL protect your rights with two steps: 41 | (1) assert copyright on the software, and (2) offer you this License 42 | giving you legal permission to copy, distribute and/or modify it. 43 | 44 | For the developers' and authors' protection, the GPL clearly explains 45 | that there is no warranty for this free software. For both users' and 46 | authors' sake, the GPL requires that modified versions be marked as 47 | changed, so that their problems will not be attributed erroneously to 48 | authors of previous versions. 49 | 50 | Some devices are designed to deny users access to install or run 51 | modified versions of the software inside them, although the manufacturer 52 | can do so. This is fundamentally incompatible with the aim of 53 | protecting users' freedom to change the software. The systematic 54 | pattern of such abuse occurs in the area of products for individuals to 55 | use, which is precisely where it is most unacceptable. Therefore, we 56 | have designed this version of the GPL to prohibit the practice for those 57 | products. If such problems arise substantially in other domains, we 58 | stand ready to extend this provision to those domains in future versions 59 | of the GPL, as needed to protect the freedom of users. 60 | 61 | Finally, every program is threatened constantly by software patents. 62 | States should not allow patents to restrict development and use of 63 | software on general-purpose computers, but in those that do, we wish to 64 | avoid the special danger that patents applied to a free program could 65 | make it effectively proprietary. To prevent this, the GPL assures that 66 | patents cannot be used to render the program non-free. 67 | 68 | The precise terms and conditions for copying, distribution and 69 | modification follow. 70 | 71 | TERMS AND CONDITIONS 72 | 73 | 0. Definitions. 74 | 75 | "This License" refers to version 3 of the GNU General Public License. 76 | 77 | "Copyright" also means copyright-like laws that apply to other kinds of 78 | works, such as semiconductor masks. 79 | 80 | "The Program" refers to any copyrightable work licensed under this 81 | License. Each licensee is addressed as "you". "Licensees" and 82 | "recipients" may be individuals or organizations. 83 | 84 | To "modify" a work means to copy from or adapt all or part of the work 85 | in a fashion requiring copyright permission, other than the making of an 86 | exact copy. The resulting work is called a "modified version" of the 87 | earlier work or a work "based on" the earlier work. 88 | 89 | A "covered work" means either the unmodified Program or a work based 90 | on the Program. 91 | 92 | To "propagate" a work means to do anything with it that, without 93 | permission, would make you directly or secondarily liable for 94 | infringement under applicable copyright law, except executing it on a 95 | computer or modifying a private copy. Propagation includes copying, 96 | distribution (with or without modification), making available to the 97 | public, and in some countries other activities as well. 98 | 99 | To "convey" a work means any kind of propagation that enables other 100 | parties to make or receive copies. Mere interaction with a user through 101 | a computer network, with no transfer of a copy, is not conveying. 102 | 103 | An interactive user interface displays "Appropriate Legal Notices" 104 | to the extent that it includes a convenient and prominently visible 105 | feature that (1) displays an appropriate copyright notice, and (2) 106 | tells the user that there is no warranty for the work (except to the 107 | extent that warranties are provided), that licensees may convey the 108 | work under this License, and how to view a copy of this License. If 109 | the interface presents a list of user commands or options, such as a 110 | menu, a prominent item in the list meets this criterion. 111 | 112 | 1. Source Code. 113 | 114 | The "source code" for a work means the preferred form of the work 115 | for making modifications to it. "Object code" means any non-source 116 | form of a work. 117 | 118 | A "Standard Interface" means an interface that either is an official 119 | standard defined by a recognized standards body, or, in the case of 120 | interfaces specified for a particular programming language, one that 121 | is widely used among developers working in that language. 122 | 123 | The "System Libraries" of an executable work include anything, other 124 | than the work as a whole, that (a) is included in the normal form of 125 | packaging a Major Component, but which is not part of that Major 126 | Component, and (b) serves only to enable use of the work with that 127 | Major Component, or to implement a Standard Interface for which an 128 | implementation is available to the public in source code form. A 129 | "Major Component", in this context, means a major essential component 130 | (kernel, window system, and so on) of the specific operating system 131 | (if any) on which the executable work runs, or a compiler used to 132 | produce the work, or an object code interpreter used to run it. 133 | 134 | The "Corresponding Source" for a work in object code form means all 135 | the source code needed to generate, install, and (for an executable 136 | work) run the object code and to modify the work, including scripts to 137 | control those activities. However, it does not include the work's 138 | System Libraries, or general-purpose tools or generally available free 139 | programs which are used unmodified in performing those activities but 140 | which are not part of the work. For example, Corresponding Source 141 | includes interface definition files associated with source files for 142 | the work, and the source code for shared libraries and dynamically 143 | linked subprograms that the work is specifically designed to require, 144 | such as by intimate data communication or control flow between those 145 | subprograms and other parts of the work. 146 | 147 | The Corresponding Source need not include anything that users 148 | can regenerate automatically from other parts of the Corresponding 149 | Source. 150 | 151 | The Corresponding Source for a work in source code form is that 152 | same work. 153 | 154 | 2. Basic Permissions. 155 | 156 | All rights granted under this License are granted for the term of 157 | copyright on the Program, and are irrevocable provided the stated 158 | conditions are met. This License explicitly affirms your unlimited 159 | permission to run the unmodified Program. The output from running a 160 | covered work is covered by this License only if the output, given its 161 | content, constitutes a covered work. This License acknowledges your 162 | rights of fair use or other equivalent, as provided by copyright law. 163 | 164 | You may make, run and propagate covered works that you do not 165 | convey, without conditions so long as your license otherwise remains 166 | in force. You may convey covered works to others for the sole purpose 167 | of having them make modifications exclusively for you, or provide you 168 | with facilities for running those works, provided that you comply with 169 | the terms of this License in conveying all material for which you do 170 | not control copyright. Those thus making or running the covered works 171 | for you must do so exclusively on your behalf, under your direction 172 | and control, on terms that prohibit them from making any copies of 173 | your copyrighted material outside their relationship with you. 174 | 175 | Conveying under any other circumstances is permitted solely under 176 | the conditions stated below. Sublicensing is not allowed; section 10 177 | makes it unnecessary. 178 | 179 | 3. Protecting Users' Legal Rights From Anti-Circumvention Law. 180 | 181 | No covered work shall be deemed part of an effective technological 182 | measure under any applicable law fulfilling obligations under article 183 | 11 of the WIPO copyright treaty adopted on 20 December 1996, or 184 | similar laws prohibiting or restricting circumvention of such 185 | measures. 186 | 187 | When you convey a covered work, you waive any legal power to forbid 188 | circumvention of technological measures to the extent such circumvention 189 | is effected by exercising rights under this License with respect to 190 | the covered work, and you disclaim any intention to limit operation or 191 | modification of the work as a means of enforcing, against the work's 192 | users, your or third parties' legal rights to forbid circumvention of 193 | technological measures. 194 | 195 | 4. Conveying Verbatim Copies. 196 | 197 | You may convey verbatim copies of the Program's source code as you 198 | receive it, in any medium, provided that you conspicuously and 199 | appropriately publish on each copy an appropriate copyright notice; 200 | keep intact all notices stating that this License and any 201 | non-permissive terms added in accord with section 7 apply to the code; 202 | keep intact all notices of the absence of any warranty; and give all 203 | recipients a copy of this License along with the Program. 204 | 205 | You may charge any price or no price for each copy that you convey, 206 | and you may offer support or warranty protection for a fee. 207 | 208 | 5. Conveying Modified Source Versions. 209 | 210 | You may convey a work based on the Program, or the modifications to 211 | produce it from the Program, in the form of source code under the 212 | terms of section 4, provided that you also meet all of these conditions: 213 | 214 | a) The work must carry prominent notices stating that you modified 215 | it, and giving a relevant date. 216 | 217 | b) The work must carry prominent notices stating that it is 218 | released under this License and any conditions added under section 219 | 7. This requirement modifies the requirement in section 4 to 220 | "keep intact all notices". 221 | 222 | c) You must license the entire work, as a whole, under this 223 | License to anyone who comes into possession of a copy. This 224 | License will therefore apply, along with any applicable section 7 225 | additional terms, to the whole of the work, and all its parts, 226 | regardless of how they are packaged. This License gives no 227 | permission to license the work in any other way, but it does not 228 | invalidate such permission if you have separately received it. 229 | 230 | d) If the work has interactive user interfaces, each must display 231 | Appropriate Legal Notices; however, if the Program has interactive 232 | interfaces that do not display Appropriate Legal Notices, your 233 | work need not make them do so. 234 | 235 | A compilation of a covered work with other separate and independent 236 | works, which are not by their nature extensions of the covered work, 237 | and which are not combined with it such as to form a larger program, 238 | in or on a volume of a storage or distribution medium, is called an 239 | "aggregate" if the compilation and its resulting copyright are not 240 | used to limit the access or legal rights of the compilation's users 241 | beyond what the individual works permit. Inclusion of a covered work 242 | in an aggregate does not cause this License to apply to the other 243 | parts of the aggregate. 244 | 245 | 6. Conveying Non-Source Forms. 246 | 247 | You may convey a covered work in object code form under the terms 248 | of sections 4 and 5, provided that you also convey the 249 | machine-readable Corresponding Source under the terms of this License, 250 | in one of these ways: 251 | 252 | a) Convey the object code in, or embodied in, a physical product 253 | (including a physical distribution medium), accompanied by the 254 | Corresponding Source fixed on a durable physical medium 255 | customarily used for software interchange. 256 | 257 | b) Convey the object code in, or embodied in, a physical product 258 | (including a physical distribution medium), accompanied by a 259 | written offer, valid for at least three years and valid for as 260 | long as you offer spare parts or customer support for that product 261 | model, to give anyone who possesses the object code either (1) a 262 | copy of the Corresponding Source for all the software in the 263 | product that is covered by this License, on a durable physical 264 | medium customarily used for software interchange, for a price no 265 | more than your reasonable cost of physically performing this 266 | conveying of source, or (2) access to copy the 267 | Corresponding Source from a network server at no charge. 268 | 269 | c) Convey individual copies of the object code with a copy of the 270 | written offer to provide the Corresponding Source. This 271 | alternative is allowed only occasionally and noncommercially, and 272 | only if you received the object code with such an offer, in accord 273 | with subsection 6b. 274 | 275 | d) Convey the object code by offering access from a designated 276 | place (gratis or for a charge), and offer equivalent access to the 277 | Corresponding Source in the same way through the same place at no 278 | further charge. You need not require recipients to copy the 279 | Corresponding Source along with the object code. If the place to 280 | copy the object code is a network server, the Corresponding Source 281 | may be on a different server (operated by you or a third party) 282 | that supports equivalent copying facilities, provided you maintain 283 | clear directions next to the object code saying where to find the 284 | Corresponding Source. Regardless of what server hosts the 285 | Corresponding Source, you remain obligated to ensure that it is 286 | available for as long as needed to satisfy these requirements. 287 | 288 | e) Convey the object code using peer-to-peer transmission, provided 289 | you inform other peers where the object code and Corresponding 290 | Source of the work are being offered to the general public at no 291 | charge under subsection 6d. 292 | 293 | A separable portion of the object code, whose source code is excluded 294 | from the Corresponding Source as a System Library, need not be 295 | included in conveying the object code work. 296 | 297 | A "User Product" is either (1) a "consumer product", which means any 298 | tangible personal property which is normally used for personal, family, 299 | or household purposes, or (2) anything designed or sold for incorporation 300 | into a dwelling. In determining whether a product is a consumer product, 301 | doubtful cases shall be resolved in favor of coverage. For a particular 302 | product received by a particular user, "normally used" refers to a 303 | typical or common use of that class of product, regardless of the status 304 | of the particular user or of the way in which the particular user 305 | actually uses, or expects or is expected to use, the product. A product 306 | is a consumer product regardless of whether the product has substantial 307 | commercial, industrial or non-consumer uses, unless such uses represent 308 | the only significant mode of use of the product. 309 | 310 | "Installation Information" for a User Product means any methods, 311 | procedures, authorization keys, or other information required to install 312 | and execute modified versions of a covered work in that User Product from 313 | a modified version of its Corresponding Source. The information must 314 | suffice to ensure that the continued functioning of the modified object 315 | code is in no case prevented or interfered with solely because 316 | modification has been made. 317 | 318 | If you convey an object code work under this section in, or with, or 319 | specifically for use in, a User Product, and the conveying occurs as 320 | part of a transaction in which the right of possession and use of the 321 | User Product is transferred to the recipient in perpetuity or for a 322 | fixed term (regardless of how the transaction is characterized), the 323 | Corresponding Source conveyed under this section must be accompanied 324 | by the Installation Information. But this requirement does not apply 325 | if neither you nor any third party retains the ability to install 326 | modified object code on the User Product (for example, the work has 327 | been installed in ROM). 328 | 329 | The requirement to provide Installation Information does not include a 330 | requirement to continue to provide support service, warranty, or updates 331 | for a work that has been modified or installed by the recipient, or for 332 | the User Product in which it has been modified or installed. Access to a 333 | network may be denied when the modification itself materially and 334 | adversely affects the operation of the network or violates the rules and 335 | protocols for communication across the network. 336 | 337 | Corresponding Source conveyed, and Installation Information provided, 338 | in accord with this section must be in a format that is publicly 339 | documented (and with an implementation available to the public in 340 | source code form), and must require no special password or key for 341 | unpacking, reading or copying. 342 | 343 | 7. Additional Terms. 344 | 345 | "Additional permissions" are terms that supplement the terms of this 346 | License by making exceptions from one or more of its conditions. 347 | Additional permissions that are applicable to the entire Program shall 348 | be treated as though they were included in this License, to the extent 349 | that they are valid under applicable law. If additional permissions 350 | apply only to part of the Program, that part may be used separately 351 | under those permissions, but the entire Program remains governed by 352 | this License without regard to the additional permissions. 353 | 354 | When you convey a copy of a covered work, you may at your option 355 | remove any additional permissions from that copy, or from any part of 356 | it. (Additional permissions may be written to require their own 357 | removal in certain cases when you modify the work.) You may place 358 | additional permissions on material, added by you to a covered work, 359 | for which you have or can give appropriate copyright permission. 360 | 361 | Notwithstanding any other provision of this License, for material you 362 | add to a covered work, you may (if authorized by the copyright holders of 363 | that material) supplement the terms of this License with terms: 364 | 365 | a) Disclaiming warranty or limiting liability differently from the 366 | terms of sections 15 and 16 of this License; or 367 | 368 | b) Requiring preservation of specified reasonable legal notices or 369 | author attributions in that material or in the Appropriate Legal 370 | Notices displayed by works containing it; or 371 | 372 | c) Prohibiting misrepresentation of the origin of that material, or 373 | requiring that modified versions of such material be marked in 374 | reasonable ways as different from the original version; or 375 | 376 | d) Limiting the use for publicity purposes of names of licensors or 377 | authors of the material; or 378 | 379 | e) Declining to grant rights under trademark law for use of some 380 | trade names, trademarks, or service marks; or 381 | 382 | f) Requiring indemnification of licensors and authors of that 383 | material by anyone who conveys the material (or modified versions of 384 | it) with contractual assumptions of liability to the recipient, for 385 | any liability that these contractual assumptions directly impose on 386 | those licensors and authors. 387 | 388 | All other non-permissive additional terms are considered "further 389 | restrictions" within the meaning of section 10. If the Program as you 390 | received it, or any part of it, contains a notice stating that it is 391 | governed by this License along with a term that is a further 392 | restriction, you may remove that term. If a license document contains 393 | a further restriction but permits relicensing or conveying under this 394 | License, you may add to a covered work material governed by the terms 395 | of that license document, provided that the further restriction does 396 | not survive such relicensing or conveying. 397 | 398 | If you add terms to a covered work in accord with this section, you 399 | must place, in the relevant source files, a statement of the 400 | additional terms that apply to those files, or a notice indicating 401 | where to find the applicable terms. 402 | 403 | Additional terms, permissive or non-permissive, may be stated in the 404 | form of a separately written license, or stated as exceptions; 405 | the above requirements apply either way. 406 | 407 | 8. Termination. 408 | 409 | You may not propagate or modify a covered work except as expressly 410 | provided under this License. Any attempt otherwise to propagate or 411 | modify it is void, and will automatically terminate your rights under 412 | this License (including any patent licenses granted under the third 413 | paragraph of section 11). 414 | 415 | However, if you cease all violation of this License, then your 416 | license from a particular copyright holder is reinstated (a) 417 | provisionally, unless and until the copyright holder explicitly and 418 | finally terminates your license, and (b) permanently, if the copyright 419 | holder fails to notify you of the violation by some reasonable means 420 | prior to 60 days after the cessation. 421 | 422 | Moreover, your license from a particular copyright holder is 423 | reinstated permanently if the copyright holder notifies you of the 424 | violation by some reasonable means, this is the first time you have 425 | received notice of violation of this License (for any work) from that 426 | copyright holder, and you cure the violation prior to 30 days after 427 | your receipt of the notice. 428 | 429 | Termination of your rights under this section does not terminate the 430 | licenses of parties who have received copies or rights from you under 431 | this License. If your rights have been terminated and not permanently 432 | reinstated, you do not qualify to receive new licenses for the same 433 | material under section 10. 434 | 435 | 9. Acceptance Not Required for Having Copies. 436 | 437 | You are not required to accept this License in order to receive or 438 | run a copy of the Program. Ancillary propagation of a covered work 439 | occurring solely as a consequence of using peer-to-peer transmission 440 | to receive a copy likewise does not require acceptance. However, 441 | nothing other than this License grants you permission to propagate or 442 | modify any covered work. These actions infringe copyright if you do 443 | not accept this License. Therefore, by modifying or propagating a 444 | covered work, you indicate your acceptance of this License to do so. 445 | 446 | 10. Automatic Licensing of Downstream Recipients. 447 | 448 | Each time you convey a covered work, the recipient automatically 449 | receives a license from the original licensors, to run, modify and 450 | propagate that work, subject to this License. You are not responsible 451 | for enforcing compliance by third parties with this License. 452 | 453 | An "entity transaction" is a transaction transferring control of an 454 | organization, or substantially all assets of one, or subdividing an 455 | organization, or merging organizations. If propagation of a covered 456 | work results from an entity transaction, each party to that 457 | transaction who receives a copy of the work also receives whatever 458 | licenses to the work the party's predecessor in interest had or could 459 | give under the previous paragraph, plus a right to possession of the 460 | Corresponding Source of the work from the predecessor in interest, if 461 | the predecessor has it or can get it with reasonable efforts. 462 | 463 | You may not impose any further restrictions on the exercise of the 464 | rights granted or affirmed under this License. For example, you may 465 | not impose a license fee, royalty, or other charge for exercise of 466 | rights granted under this License, and you may not initiate litigation 467 | (including a cross-claim or counterclaim in a lawsuit) alleging that 468 | any patent claim is infringed by making, using, selling, offering for 469 | sale, or importing the Program or any portion of it. 470 | 471 | 11. Patents. 472 | 473 | A "contributor" is a copyright holder who authorizes use under this 474 | License of the Program or a work on which the Program is based. The 475 | work thus licensed is called the contributor's "contributor version". 476 | 477 | A contributor's "essential patent claims" are all patent claims 478 | owned or controlled by the contributor, whether already acquired or 479 | hereafter acquired, that would be infringed by some manner, permitted 480 | by this License, of making, using, or selling its contributor version, 481 | but do not include claims that would be infringed only as a 482 | consequence of further modification of the contributor version. For 483 | purposes of this definition, "control" includes the right to grant 484 | patent sublicenses in a manner consistent with the requirements of 485 | this License. 486 | 487 | Each contributor grants you a non-exclusive, worldwide, royalty-free 488 | patent license under the contributor's essential patent claims, to 489 | make, use, sell, offer for sale, import and otherwise run, modify and 490 | propagate the contents of its contributor version. 491 | 492 | In the following three paragraphs, a "patent license" is any express 493 | agreement or commitment, however denominated, not to enforce a patent 494 | (such as an express permission to practice a patent or covenant not to 495 | sue for patent infringement). To "grant" such a patent license to a 496 | party means to make such an agreement or commitment not to enforce a 497 | patent against the party. 498 | 499 | If you convey a covered work, knowingly relying on a patent license, 500 | and the Corresponding Source of the work is not available for anyone 501 | to copy, free of charge and under the terms of this License, through a 502 | publicly available network server or other readily accessible means, 503 | then you must either (1) cause the Corresponding Source to be so 504 | available, or (2) arrange to deprive yourself of the benefit of the 505 | patent license for this particular work, or (3) arrange, in a manner 506 | consistent with the requirements of this License, to extend the patent 507 | license to downstream recipients. "Knowingly relying" means you have 508 | actual knowledge that, but for the patent license, your conveying the 509 | covered work in a country, or your recipient's use of the covered work 510 | in a country, would infringe one or more identifiable patents in that 511 | country that you have reason to believe are valid. 512 | 513 | If, pursuant to or in connection with a single transaction or 514 | arrangement, you convey, or propagate by procuring conveyance of, a 515 | covered work, and grant a patent license to some of the parties 516 | receiving the covered work authorizing them to use, propagate, modify 517 | or convey a specific copy of the covered work, then the patent license 518 | you grant is automatically extended to all recipients of the covered 519 | work and works based on it. 520 | 521 | A patent license is "discriminatory" if it does not include within 522 | the scope of its coverage, prohibits the exercise of, or is 523 | conditioned on the non-exercise of one or more of the rights that are 524 | specifically granted under this License. You may not convey a covered 525 | work if you are a party to an arrangement with a third party that is 526 | in the business of distributing software, under which you make payment 527 | to the third party based on the extent of your activity of conveying 528 | the work, and under which the third party grants, to any of the 529 | parties who would receive the covered work from you, a discriminatory 530 | patent license (a) in connection with copies of the covered work 531 | conveyed by you (or copies made from those copies), or (b) primarily 532 | for and in connection with specific products or compilations that 533 | contain the covered work, unless you entered into that arrangement, 534 | or that patent license was granted, prior to 28 March 2007. 535 | 536 | Nothing in this License shall be construed as excluding or limiting 537 | any implied license or other defenses to infringement that may 538 | otherwise be available to you under applicable patent law. 539 | 540 | 12. No Surrender of Others' Freedom. 541 | 542 | If conditions are imposed on you (whether by court order, agreement or 543 | otherwise) that contradict the conditions of this License, they do not 544 | excuse you from the conditions of this License. If you cannot convey a 545 | covered work so as to satisfy simultaneously your obligations under this 546 | License and any other pertinent obligations, then as a consequence you may 547 | not convey it at all. For example, if you agree to terms that obligate you 548 | to collect a royalty for further conveying from those to whom you convey 549 | the Program, the only way you could satisfy both those terms and this 550 | License would be to refrain entirely from conveying the Program. 551 | 552 | 13. Use with the GNU Affero General Public License. 553 | 554 | Notwithstanding any other provision of this License, you have 555 | permission to link or combine any covered work with a work licensed 556 | under version 3 of the GNU Affero General Public License into a single 557 | combined work, and to convey the resulting work. The terms of this 558 | License will continue to apply to the part which is the covered work, 559 | but the special requirements of the GNU Affero General Public License, 560 | section 13, concerning interaction through a network will apply to the 561 | combination as such. 562 | 563 | 14. Revised Versions of this License. 564 | 565 | The Free Software Foundation may publish revised and/or new versions of 566 | the GNU General Public License from time to time. Such new versions will 567 | be similar in spirit to the present version, but may differ in detail to 568 | address new problems or concerns. 569 | 570 | Each version is given a distinguishing version number. If the 571 | Program specifies that a certain numbered version of the GNU General 572 | Public License "or any later version" applies to it, you have the 573 | option of following the terms and conditions either of that numbered 574 | version or of any later version published by the Free Software 575 | Foundation. If the Program does not specify a version number of the 576 | GNU General Public License, you may choose any version ever published 577 | by the Free Software Foundation. 578 | 579 | If the Program specifies that a proxy can decide which future 580 | versions of the GNU General Public License can be used, that proxy's 581 | public statement of acceptance of a version permanently authorizes you 582 | to choose that version for the Program. 583 | 584 | Later license versions may give you additional or different 585 | permissions. However, no additional obligations are imposed on any 586 | author or copyright holder as a result of your choosing to follow a 587 | later version. 588 | 589 | 15. Disclaimer of Warranty. 590 | 591 | THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY 592 | APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT 593 | HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY 594 | OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, 595 | THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 596 | PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM 597 | IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF 598 | ALL NECESSARY SERVICING, REPAIR OR CORRECTION. 599 | 600 | 16. Limitation of Liability. 601 | 602 | IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING 603 | WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS 604 | THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY 605 | GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE 606 | USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF 607 | DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD 608 | PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), 609 | EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF 610 | SUCH DAMAGES. 611 | 612 | 17. Interpretation of Sections 15 and 16. 613 | 614 | If the disclaimer of warranty and limitation of liability provided 615 | above cannot be given local legal effect according to their terms, 616 | reviewing courts shall apply local law that most closely approximates 617 | an absolute waiver of all civil liability in connection with the 618 | Program, unless a warranty or assumption of liability accompanies a 619 | copy of the Program in return for a fee. 620 | 621 | END OF TERMS AND CONDITIONS 622 | 623 | How to Apply These Terms to Your New Programs 624 | 625 | If you develop a new program, and you want it to be of the greatest 626 | possible use to the public, the best way to achieve this is to make it 627 | free software which everyone can redistribute and change under these terms. 628 | 629 | To do so, attach the following notices to the program. It is safest 630 | to attach them to the start of each source file to most effectively 631 | state the exclusion of warranty; and each file should have at least 632 | the "copyright" line and a pointer to where the full notice is found. 633 | 634 | 635 | Copyright (C) 636 | 637 | This program is free software: you can redistribute it and/or modify 638 | it under the terms of the GNU General Public License as published by 639 | the Free Software Foundation, either version 3 of the License, or 640 | (at your option) any later version. 641 | 642 | This program is distributed in the hope that it will be useful, 643 | but WITHOUT ANY WARRANTY; without even the implied warranty of 644 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 645 | GNU General Public License for more details. 646 | 647 | You should have received a copy of the GNU General Public License 648 | along with this program. If not, see . 649 | 650 | Also add information on how to contact you by electronic and paper mail. 651 | 652 | If the program does terminal interaction, make it output a short 653 | notice like this when it starts in an interactive mode: 654 | 655 | Copyright (C) 656 | This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'. 657 | This is free software, and you are welcome to redistribute it 658 | under certain conditions; type `show c' for details. 659 | 660 | The hypothetical commands `show w' and `show c' should show the appropriate 661 | parts of the General Public License. Of course, your program's commands 662 | might be different; for a GUI interface, you would use an "about box". 663 | 664 | You should also get your employer (if you work as a programmer) or school, 665 | if any, to sign a "copyright disclaimer" for the program, if necessary. 666 | For more information on this, and how to apply and follow the GNU GPL, see 667 | . 668 | 669 | The GNU General Public License does not permit incorporating your program 670 | into proprietary programs. If your program is a subroutine library, you 671 | may consider it more useful to permit linking proprietary applications with 672 | the library. If this is what you want to do, use the GNU Lesser General 673 | Public License instead of this License. But first, please read 674 | . 675 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Laravel Styleguide 2 | ![build](https://github.com/xpersonas/laravel-styleguide/workflows/build/badge.svg) 3 | [![PHP version](https://badge.fury.io/ph/xpersonas%2Flaravel-styleguide.svg)](https://badge.fury.io/ph/xpersonas%2Flaravel-styleguide) 4 | [![Total Downloads](https://poser.pugx.org/xpersonas/laravel-styleguide/downloads)](//packagist.org/packages/xpersonas/laravel-styleguide) 5 | [![License](https://poser.pugx.org/xpersonas/laravel-styleguide/license)](https://github.com/xpersonas/laravel-styleguide/blob/master/LICENSE.txt) 6 | [![Maintainability](https://api.codeclimate.com/v1/badges/1285e02e470cea7d401d/maintainability)](https://codeclimate.com/github/xpersonas/laravel-styleguide/maintainability) 7 | 8 | This package allows admins to create a custom styleguide for Laravel project development. 9 | 10 | **Basic Elements** 11 | Choose from a list of basic elements like headings, text, tables, etc.. 12 | 13 | ![svg-main-x](https://user-images.githubusercontent.com/5023924/88303382-96958f00-cccc-11ea-8a8a-5b86f75fb556.jpg) 14 | 15 | **Colors** 16 | Provide a list of colors with class name, description, and hex value. 17 | 18 | ![sg-colors-x](https://user-images.githubusercontent.com/5023924/88303381-96958f00-cccc-11ea-9bca-c42a90494b22.jpg) 19 | 20 | **Custom Patterns** 21 | Admins can also create custom patterns with a built in codemirror textarea. 22 | 23 | ![sg-pattern-x](https://user-images.githubusercontent.com/5023924/88303380-95fcf880-cccc-11ea-9c65-05a2f0302329.jpg) 24 | 25 | ## Installation 26 | 27 | This package comes with 3 models: basic settings, colors, and patterns. Run the following 28 | 29 | ``` 30 | composer require xpersonas/laravel-styleguide 31 | php artisan vendor:publish --tag=xpersonas-styleguide 32 | php artisan migrate 33 | ``` 34 | 35 | ## Usage 36 | 37 | The styleguide provides a Laravel component that can be dropped in any of your templates. This allows you to drop it in a page where your styles will be applied to all the elements contained within the styleguide. 38 | 39 | Add this to your template: 40 | ``` 41 | 42 | ``` 43 | 44 | Edit your Styleguide settings by visiting `/admin/styleguide` on your site. 45 | 46 | ## Stylesheets 47 | 48 | The styleguide comes with a limited stylesheet for layout purposes. Include this only on your styleguide page if needed. 49 | 50 | ``` 51 | 52 | ``` 53 | 54 | ## Protecting Routes 55 | 56 | There are several CRUD-related pages that will need protection from anonymous users. Please use what ever authentication system you are using to ensure these pages are safe from the public. 57 | 58 | ``` 59 | // Route setup. 60 | Route::get('admin/styleguide/preview', '\Xpersonas\Styleguide\Http\Controllers\StyleguideController@index')->name('simple-styleguide'); 61 | 62 | Route::resource('admin/styleguide/patterns','Xpersonas\Styleguide\Http\Controllers\StyleguidePatternController', ['names' => 'pattern'])->middleware(['web']); 63 | Route::resource('admin/styleguide/colors','Xpersonas\Styleguide\Http\Controllers\StyleguideColorController', ['names' => 'color'])->middleware(['web']); 64 | Route::resource('admin/styleguide/basics','Xpersonas\Styleguide\Http\Controllers\StyleguideBasicsController', ['names' => 'basics'])->middleware(['web']); 65 | 66 | // Wildcard route to protect. 67 | admin/styleguide/* 68 | ``` 69 | 70 | ## Nova Ready (optional) 71 | https://nova.laravel.com 72 | 73 | This package is Nova-ready. If you want to manage styleguide settings, patterns, and colors within a "beautifully designed administration panel" then follow the instructions below. 74 | 75 | Screen Shot 2020-08-13 at 12 29 12 PM 76 | 77 | ### Installation 78 | 79 | Add our Nova Tool to your Nova Service Proivder: 80 | 81 | ``` 82 | // app/Providers/NovaServiceProvider.php 83 | 84 | public function tools() 85 | { 86 | return [ 87 | new \Xpersonas\Styleguide\Providers\StyleguideNovaTool(), 88 | ]; 89 | } 90 | ``` 91 | 92 | ### Laravel Nova Color Field (optional) 93 | 94 | This package is also compatible with the excellent Laravel Nova Color Field from [timothyasp](https://github.com/timothyasp/nova-color-field). 95 | 96 | ``` 97 | composer require timothyasp/nova-color-field 98 | ``` 99 | 100 | Screen Shot 2020-08-13 at 12 09 42 PM 101 | 102 | ## Contribute 103 | 104 | https://github.com/xpersonas/laravel-styleguide/pulls 105 | 106 | ## Author 107 | 108 | **[xpersonas](mailto:justin.neel@gmail.com)** 109 | -------------------------------------------------------------------------------- /app/Http/Controllers/Controller.php: -------------------------------------------------------------------------------- 1 | isEmpty()) { 25 | $id = $basics->last()->id; 26 | return redirect()->route('basics.edit', $id)->with('success', 'Styleguide color is successfully saved.'); 27 | } else { 28 | $styleguideBasics = new StyleguideBasics(); 29 | $fillable = $styleguideBasics->getFillable(); 30 | 31 | return view('styleguide::basics/edit', compact('fillable')); 32 | } 33 | } 34 | 35 | /** 36 | * Show the form for creating a new resource. 37 | * 38 | * @return \Illuminate\Contracts\Foundation\Application|\Illuminate\Contracts\View\Factory|\Illuminate\View\View 39 | */ 40 | public function create() 41 | { 42 | $styleguideBasics = new StyleguideBasics(); 43 | $fillable = $styleguideBasics->getFillable(); 44 | 45 | return view('styleguide::basics/edit', compact('fillable')); 46 | } 47 | 48 | /** 49 | * Store a newly created resource in storage. 50 | * 51 | * @param \Illuminate\Http\Request $request 52 | * @return \Illuminate\Http\RedirectResponse 53 | */ 54 | public function store(Request $request) 55 | { 56 | $basics = collect($request->input('basics')) 57 | ->mapWithKeys(function ($value) { 58 | return [$value => 1]; 59 | }); 60 | 61 | StyleguideBasics::create($basics->toArray()); 62 | 63 | return redirect()->route('basics.index')->with('success', 'Styleguide color is successfully saved.'); 64 | } 65 | 66 | /** 67 | * Show the form for editing the specified resource. 68 | * 69 | * @return \Illuminate\Contracts\Foundation\Application|\Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector 70 | */ 71 | public function edit($id) 72 | { 73 | $basics = StyleguideBasics::findOrFail($id); 74 | $fillable = $basics->getFillable(); 75 | 76 | return view('styleguide::basics/edit', compact('basics', 'fillable')); 77 | } 78 | 79 | /** 80 | * Update the specified resource in storage. 81 | * 82 | * @param \Illuminate\Http\Request $request 83 | * @param int $id 84 | * @return \Illuminate\Http\RedirectResponse 85 | */ 86 | public function update(Request $request, $id) 87 | { 88 | $basics = collect($request->input('basics')) 89 | ->mapWithKeys(function ($value) { 90 | return [$value => 1]; 91 | }); 92 | 93 | StyleguideBasics::updateOrCreate(['id' => $id], $basics->toArray()); 94 | 95 | return redirect()->route('basics.edit', $id)->with('success', 'Styleguide color is successfully updated.'); 96 | } 97 | } 98 | -------------------------------------------------------------------------------- /app/Http/Controllers/StyleguideColorController.php: -------------------------------------------------------------------------------- 1 | all()); 44 | return redirect()->route('color.index')->with('success', 'Styleguide color is successfully saved.'); 45 | } 46 | 47 | /** 48 | * Show the form for editing the specified resource. 49 | * 50 | * @param \Xpersonas\Styleguide\StyleguideColor $color 51 | * @return \Illuminate\Contracts\Foundation\Application|\Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector 52 | */ 53 | public function edit(StyleguideColor $color) 54 | { 55 | return view('styleguide::colors/edit', compact('color')); 56 | } 57 | 58 | /** 59 | * Update the specified resource in storage. 60 | * 61 | * @param \Xpersonas\Styleguide\Http\Requests\StyleguideColorPost $request 62 | * @param $id 63 | * @return \Illuminate\Contracts\Foundation\Application|\Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector 64 | */ 65 | public function update(StyleguideColorPost $request, $id) 66 | { 67 | StyleguideColor::updateOrCreate(['id' => $id], $request->all()); 68 | return redirect()->route('color.index')->with('success', 'Styleguide color is successfully updated.'); 69 | } 70 | 71 | /** 72 | * Remove the specified resource from storage. 73 | * 74 | * @param \Xpersonas\Styleguide\StyleguideColor $color 75 | * @return \Illuminate\Contracts\Foundation\Application|\Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector 76 | */ 77 | public function destroy(StyleguideColor $color) 78 | { 79 | $color->delete(); 80 | return redirect()->route('color.index')->with('success', 'Styleguide color is successfully deleted.'); 81 | } 82 | } 83 | -------------------------------------------------------------------------------- /app/Http/Controllers/StyleguideController.php: -------------------------------------------------------------------------------- 1 | validate([ 36 | 'title' => 'required|max:255', 37 | 'description' => 'required', 38 | 'pattern' => 'required', 39 | ]); 40 | 41 | StyleguidePattern::create($validatedData); 42 | 43 | return redirect()->route('pattern.index')->with('success', 'Styleguide pattern is successfully saved.'); 44 | } 45 | 46 | /** 47 | * Show the form for editing the specified resource. 48 | * 49 | * @return \Illuminate\Contracts\Foundation\Application|\Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector 50 | */ 51 | public function edit(StyleguidePattern $pattern) 52 | { 53 | return view('styleguide::patterns/edit', compact('pattern')); 54 | } 55 | 56 | /** 57 | * Update the specified resource in storage. 58 | * 59 | * @param \Illuminate\Http\Request $request 60 | * @param int $id 61 | * @return \Illuminate\Contracts\Foundation\Application|\Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector 62 | */ 63 | public function update(Request $request, $id) 64 | { 65 | $validatedData = $request->validate([ 66 | 'title' => 'required|max:255', 67 | 'description' => 'required', 68 | 'pattern' => 'required', 69 | ]); 70 | 71 | StyleguidePattern::updateOrCreate(['id' => $id], $validatedData); 72 | 73 | return redirect()->route('pattern.index')->with('success', 'Styleguide pattern is successfully updated.'); 74 | } 75 | 76 | /** 77 | * Remove the specified resource from storage. 78 | * 79 | * @return \Illuminate\Contracts\Foundation\Application|\Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector 80 | */ 81 | public function destroy(StyleguidePattern $pattern) 82 | { 83 | $pattern->delete(); 84 | 85 | return redirect()->route('pattern.index')->with('success', 'Styleguide pattern is successfully deleted.'); 86 | } 87 | } 88 | -------------------------------------------------------------------------------- /app/Http/Requests/StyleguideColorPost.php: -------------------------------------------------------------------------------- 1 | 'required|max:255', 29 | 'description' => 'required', 30 | 'hex' => 'regex:/^#?([0-9a-fA-F]{3}){1,2}$/i', 31 | ]; 32 | } 33 | 34 | /** 35 | * Get the error messages for the defined validation rules. 36 | * 37 | * @return array 38 | */ 39 | public function messages() 40 | { 41 | return [ 42 | 'hex.regex' => 'Invalid hexadecimal color. Please enter the 3 or 6 43 | character code. Hashtag is optional and not required.', 44 | ]; 45 | } 46 | } 47 | -------------------------------------------------------------------------------- /app/Nova/StyleguideBasics.php: -------------------------------------------------------------------------------- 1 | isEmpty()) { 58 | return true; 59 | } 60 | 61 | return false; 62 | } 63 | 64 | public function authorizedToDelete(Request $request) 65 | { 66 | return false; 67 | } 68 | 69 | /** 70 | * Get the fields displayed by the resource. 71 | * 72 | * @param \Illuminate\Http\Request $request 73 | * @return array 74 | */ 75 | public function fields(Request $request) 76 | { 77 | return [ 78 | ID::make() 79 | ->hideFromIndex() 80 | ->hideFromDetail() 81 | ->hideWhenCreating() 82 | ->hideWhenUpdating(), 83 | Boolean::make('headings'), 84 | Boolean::make('text'), 85 | Boolean::make('lists'), 86 | Boolean::make('blockquote'), 87 | Boolean::make('rule'), 88 | Boolean::make('table'), 89 | Boolean::make('breadcrumbs'), 90 | Boolean::make('forms'), 91 | Boolean::make('buttons'), 92 | ]; 93 | } 94 | 95 | /** 96 | * Get the cards available for the request. 97 | * 98 | * @param \Illuminate\Http\Request $request 99 | * @return array 100 | */ 101 | public function cards(Request $request) 102 | { 103 | return []; 104 | } 105 | 106 | /** 107 | * Get the filters available for the resource. 108 | * 109 | * @param \Illuminate\Http\Request $request 110 | * @return array 111 | */ 112 | public function filters(Request $request) 113 | { 114 | return []; 115 | } 116 | 117 | /** 118 | * Get the lenses available for the resource. 119 | * 120 | * @param \Illuminate\Http\Request $request 121 | * @return array 122 | */ 123 | public function lenses(Request $request) 124 | { 125 | return []; 126 | } 127 | 128 | /** 129 | * Get the actions available for the resource. 130 | * 131 | * @param \Illuminate\Http\Request $request 132 | * @return array 133 | */ 134 | public function actions(Request $request) 135 | { 136 | return []; 137 | } 138 | } 139 | -------------------------------------------------------------------------------- /app/Nova/StyleguideColor.php: -------------------------------------------------------------------------------- 1 | sortable(), 55 | Date::make('CREATED', 'created_at') 56 | ->sortable() 57 | ->format('MMMM DD') 58 | ->exceptOnForms(), 59 | Text::make('class') 60 | ->sortable(), 61 | Trix::make('description')->hideFromIndex()->alwaysShow(), 62 | $this->getColorField()->rules('required', 'regex:/^#?([0-9a-fA-F]{3}){1,2}$/i') 63 | ]; 64 | } 65 | 66 | /** 67 | * Check for Color class. 68 | * 69 | * If Timothyasp\Color\Color exists, return Color field. 70 | * Otherwise return plain textfield. 71 | * 72 | * @return \Laravel\Nova\Fields\Text 73 | */ 74 | public function getColorField() 75 | { 76 | if (class_exists('\Timothyasp\Color\Color')) { 77 | $colorField = \Timothyasp\Color\Color::make('Color', 'hex'); 78 | } else { 79 | $colorField = Text::make('Color', 'hex'); 80 | } 81 | 82 | return $colorField; 83 | } 84 | 85 | /** 86 | * Customizations for color detail page. 87 | * 88 | * @param \Laravel\Nova\Http\Requests\NovaRequest $request 89 | * 90 | * @return array 91 | */ 92 | public function fieldsForDetail(NovaRequest $request) 93 | { 94 | return [ 95 | Date::make('Created', 'created_at') 96 | ->format('MMMM DD'), 97 | Text::make('Class', 'class'), 98 | Trix::make('Description', 'description')->alwaysShow(), 99 | Text::make('Color', function () { 100 | return "{$this->hex}"; 101 | })->asHtml() 102 | ]; 103 | } 104 | 105 | /** 106 | * Customizations for the color index page. 107 | * 108 | * @param \Laravel\Nova\Http\Requests\NovaRequest $request 109 | * 110 | * @return array 111 | */ 112 | public function fieldsForIndex(NovaRequest $request) 113 | { 114 | return [ 115 | Date::make('Created', 'created_at') 116 | ->format('MMMM DD'), 117 | Text::make('Class', 'class'), 118 | Text::make('Color', function () { 119 | return "{$this->hex}"; 120 | })->asHtml() 121 | ]; 122 | } 123 | 124 | /** 125 | * Get the cards available for the request. 126 | * 127 | * @param \Illuminate\Http\Request $request 128 | * @return array 129 | */ 130 | public function cards(Request $request) 131 | { 132 | return []; 133 | } 134 | 135 | /** 136 | * Get the filters available for the resource. 137 | * 138 | * @param \Illuminate\Http\Request $request 139 | * @return array 140 | */ 141 | public function filters(Request $request) 142 | { 143 | return []; 144 | } 145 | 146 | /** 147 | * Get the lenses available for the resource. 148 | * 149 | * @param \Illuminate\Http\Request $request 150 | * @return array 151 | */ 152 | public function lenses(Request $request) 153 | { 154 | return []; 155 | } 156 | 157 | /** 158 | * Get the actions available for the resource. 159 | * 160 | * @param \Illuminate\Http\Request $request 161 | * @return array 162 | */ 163 | public function actions(Request $request) 164 | { 165 | return []; 166 | } 167 | } 168 | -------------------------------------------------------------------------------- /app/Nova/StyleguidePattern.php: -------------------------------------------------------------------------------- 1 | sortable(), 56 | Text::make('title')->sortable(), 57 | Trix::make('description')->hideFromIndex()->alwaysShow(), 58 | Code::make('pattern'), 59 | ]; 60 | } 61 | 62 | public function fieldsForDetail($request) 63 | { 64 | return [ 65 | Date::make('Created', 'created_at') 66 | ->format('MMMM DD'), 67 | Text::make('title')->sortable(), 68 | Trix::make('description')->hideFromIndex()->alwaysShow(), 69 | Code::make('pattern'), 70 | ]; 71 | } 72 | 73 | public function fieldsForIndex($request) 74 | { 75 | return [ 76 | Date::make('Created', 'created_at') 77 | ->format('MMMM DD'), 78 | Text::make('title')->sortable(), 79 | Trix::make('description')->hideFromIndex()->alwaysShow(), 80 | Code::make('pattern'), 81 | ]; 82 | } 83 | /** 84 | * Get the cards available for the request. 85 | * 86 | * @param \Illuminate\Http\Request $request 87 | * @return array 88 | */ 89 | public function cards(Request $request) 90 | { 91 | return []; 92 | } 93 | 94 | /** 95 | * Get the filters available for the resource. 96 | * 97 | * @param \Illuminate\Http\Request $request 98 | * @return array 99 | */ 100 | public function filters(Request $request) 101 | { 102 | return []; 103 | } 104 | 105 | /** 106 | * Get the lenses available for the resource. 107 | * 108 | * @param \Illuminate\Http\Request $request 109 | * @return array 110 | */ 111 | public function lenses(Request $request) 112 | { 113 | return []; 114 | } 115 | 116 | /** 117 | * Get the actions available for the resource. 118 | * 119 | * @param \Illuminate\Http\Request $request 120 | * @return array 121 | */ 122 | public function actions(Request $request) 123 | { 124 | return []; 125 | } 126 | } 127 | -------------------------------------------------------------------------------- /app/Observers/StyleguideColorObserver.php: -------------------------------------------------------------------------------- 1 | hex = $this->formatHexValue($color->hex); 13 | } 14 | 15 | /** 16 | * Add pound sign to beginning of string if not present already. 17 | * 18 | * @param $value 19 | * 20 | * @return string 21 | */ 22 | public function formatHexValue($value) 23 | { 24 | if (! Str::startsWith($value, '#')) { 25 | return '#'. $value; 26 | } 27 | 28 | return $value; 29 | } 30 | } 31 | -------------------------------------------------------------------------------- /app/Providers/StyleguideColorModelServiceProvider.php: -------------------------------------------------------------------------------- 1 | app->make('Xpersonas\Styleguide\Http\Controllers\StyleguideController'); 21 | 22 | // Package views. 23 | $this->loadViewsFrom(__DIR__.'/../../resources/views', 'styleguide'); 24 | } 25 | 26 | /** 27 | * Bootstrap services. 28 | * 29 | * @return void 30 | */ 31 | public function boot() 32 | { 33 | // Package routes. 34 | include __DIR__.'/../../routes/routes.php'; 35 | 36 | // Package views. 37 | $this->loadViewsFrom(__DIR__.'/../../resources/views', 'styleguide'); 38 | 39 | // Package migrations. 40 | $this->loadMigrationsFrom(__DIR__.'/../../database/migrations/'); 41 | 42 | $this->loadViewComponentsAs('styleguide', [ 43 | Base::class, 44 | ]); 45 | 46 | $this->publishes([ 47 | __DIR__.'/../../public/js/styleguide.js' => 48 | public_path('js/vendor/xpersonas/styleguide.js'), 49 | __DIR__.'/../../public/css/styleguide.css' => 50 | public_path('css/vendor/xpersonas/styleguide.css'), 51 | __DIR__.'/../../database/seeds/StyleguideBasicsSeeder.php' => 52 | database_path('seeds/StyleguideBasicsSeeder.php'), 53 | __DIR__.'/../../database/seeds/StyleguidePatternSeeder.php' => 54 | database_path('seeds/StyleguidePatternSeeder.php'), 55 | __DIR__.'/../../database/seeds/StyleguideColorSeeder.php' => 56 | database_path('seeds/StyleguideColorSeeder.php'), 57 | __DIR__.'/../../database/factories/StyleguideBasicsFactory.php' => 58 | database_path('factories/StyleguideBasicsFactory.php'), 59 | __DIR__.'/../../database/factories/StyleguideColorFactory.php' => 60 | database_path('factories/StyleguideColorFactory.php'), 61 | __DIR__.'/../../database/factories/StyleguidePatternFactory.php' => 62 | database_path('factories/StyleguidePatternFactory.php'), 63 | ], 'xpersonas-styleguide'); 64 | } 65 | } 66 | -------------------------------------------------------------------------------- /app/StyleguideBasics.php: -------------------------------------------------------------------------------- 1 | true]); 36 | } 37 | 38 | $colorsEntities = StyleguideColor::all(); 39 | $colors = null; 40 | foreach ($colorsEntities as $key => $value) { 41 | $rgb = $this->hex2rgb($value->hex); 42 | $colors[$key] = [ 43 | 'class' => $value->class, 44 | 'description' => $value->description, 45 | 'hex' => $value->hex, 46 | 'rgb' => implode(', ', $rgb), 47 | ]; 48 | } 49 | 50 | $patternsEntities = StyleguidePattern::all(); 51 | $patterns = null; 52 | foreach ($patternsEntities as $key => $value) { 53 | $patterns[$key] = [ 54 | 'id' => $value->id, 55 | 'title' => $value->title, 56 | 'description' => $value->description, 57 | 'pattern' => $value->pattern, 58 | ]; 59 | } 60 | 61 | $basicSettings = StyleguideBasics::all(); 62 | if ($basicSettings->isEmpty() || $this->isDefaultComponentsEmpty($basicSettings[0])) { 63 | $basics = null; 64 | } else { 65 | $basics = StyleguideBasics::findOrFail($basicSettings[0]->id); 66 | $fillable = $basics->getFillable(); 67 | } 68 | 69 | return view( 70 | 'styleguide::components.base', 71 | compact('colors', 'patterns', 'basics') 72 | ); 73 | } 74 | 75 | public function isDefaultComponentsEmpty($component) 76 | { 77 | if (!$component->headings && 78 | !$component->text && 79 | !$component->lists && 80 | !$component->blockquote && 81 | !$component->rule && 82 | !$component->table && 83 | !$component->breadcrumbs && 84 | !$component->forms && 85 | !$component->buttons 86 | ) { 87 | return true; 88 | } 89 | } 90 | 91 | /** 92 | * Convert hex values to rgb. 93 | * 94 | * @param $colour 95 | * 96 | * @return array|bool 97 | */ 98 | public function hex2rgb($colour) 99 | { 100 | if ($colour[0] == '#') { 101 | $colour = substr($colour, 1); 102 | } 103 | 104 | if (strlen($colour) == 6) { 105 | [$r, $g, $b] = [ 106 | $colour[0].$colour[1], $colour[2].$colour[3], 107 | $colour[4].$colour[5], 108 | ]; 109 | } elseif (strlen($colour) == 3) { 110 | [$r, $g, $b] = [ 111 | $colour[0].$colour[0], $colour[1].$colour[1], 112 | $colour[2].$colour[2], 113 | ]; 114 | } else { 115 | return []; 116 | } 117 | 118 | $r = hexdec($r); 119 | $g = hexdec($g); 120 | $b = hexdec($b); 121 | 122 | return ['red' => $r, 'green' => $g, 'blue' => $b]; 123 | } 124 | } 125 | -------------------------------------------------------------------------------- /composer.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "xpersonas/laravel-styleguide", 3 | "description": "Simple styleguide for use with Laravel projects. Quickly create a page of html elements and components to be styled with your front end stylesheets.", 4 | "keywords": ["laravel", "styleguide"], 5 | "type": "project", 6 | "license": "GPL-3.0-or-later", 7 | "authors": [ 8 | { 9 | "name": "xpersonas", 10 | "email": "justin.neel@gmail.com" 11 | } 12 | ], 13 | "autoload": { 14 | "psr-4": { 15 | "Xpersonas\\Styleguide\\": "app/" 16 | } 17 | }, 18 | "autoload-dev": { 19 | "psr-4": { 20 | "Xpersonas\\Styleguide\\Tests\\": "tests/" 21 | } 22 | }, 23 | "require": { 24 | "php": ">=7.3", 25 | "eloquent/composer-npm-bridge": "^5.0" 26 | }, 27 | "require-dev": { 28 | "phpunit/phpunit": "^9.2", 29 | "orchestra/testbench": "^5.3", 30 | "squizlabs/php_codesniffer": "*" 31 | }, 32 | "suggest": { 33 | "timothyasp/nova-color-field":"If using Nova, consider using this color picker." 34 | }, 35 | "extra": { 36 | "laravel": { 37 | "providers": [ 38 | "Xpersonas\\Styleguide\\Providers\\StyleguideColorModelServiceProvider", 39 | "Xpersonas\\Styleguide\\Providers\\StyleguideServiceProvider" 40 | ] 41 | }, 42 | "npm-bridge": { 43 | "timeout": 9000, 44 | "optional": true 45 | } 46 | } 47 | } 48 | -------------------------------------------------------------------------------- /database/factories/StyleguideBasicsFactory.php: -------------------------------------------------------------------------------- 1 | define(StyleguideBasics::class, function (Faker $faker) { 9 | return [ 10 | 'headings' => $faker->boolean(75), 11 | 'text' => $faker->boolean(75), 12 | 'lists' => $faker->boolean(75), 13 | 'blockquote' => $faker->boolean(75), 14 | 'rule' => $faker->boolean(75), 15 | 'table' => $faker->boolean(75), 16 | 'breadcrumbs' => $faker->boolean(75), 17 | 'forms' => $faker->boolean(75), 18 | 'buttons' => $faker->boolean(75), 19 | ]; 20 | }); 21 | -------------------------------------------------------------------------------- /database/factories/StyleguideColorFactory.php: -------------------------------------------------------------------------------- 1 | define(StyleguideColor::class, function (Faker $faker) { 9 | return [ 10 | 'class' => $faker->word, 11 | 'description' => $faker->text, 12 | 'hex' => $faker->hexcolor 13 | ]; 14 | }); 15 | -------------------------------------------------------------------------------- /database/factories/StyleguidePatternFactory.php: -------------------------------------------------------------------------------- 1 | define(StyleguidePattern::class, function (Faker $faker) { 9 | return [ 10 | 'title' => $faker->word, 11 | 'description' => $faker->text, 12 | 'pattern' => $faker->randomHtml() 13 | ]; 14 | }); 15 | -------------------------------------------------------------------------------- /database/migrations/2020_07_07_201044_create_styleguide_patterns_table.php: -------------------------------------------------------------------------------- 1 | id(); 18 | $table->string('title'); 19 | $table->longText('description'); 20 | $table->longText('pattern'); 21 | $table->timestamps(); 22 | }); 23 | } 24 | 25 | /** 26 | * Reverse the migrations. 27 | * 28 | * @return void 29 | */ 30 | public function down() 31 | { 32 | Schema::dropIfExists('styleguide_patterns'); 33 | } 34 | } 35 | -------------------------------------------------------------------------------- /database/migrations/2020_07_09_171757_create_styleguide_colors_table.php: -------------------------------------------------------------------------------- 1 | id(); 18 | $table->string('class'); 19 | $table->longText('description'); 20 | $table->string('hex'); 21 | $table->timestamps(); 22 | }); 23 | } 24 | 25 | /** 26 | * Reverse the migrations. 27 | * 28 | * @return void 29 | */ 30 | public function down() 31 | { 32 | Schema::dropIfExists('styleguide_colors'); 33 | } 34 | } 35 | -------------------------------------------------------------------------------- /database/migrations/2020_07_11_145517_create_styleguide_basics_table.php: -------------------------------------------------------------------------------- 1 | id(); 18 | $table->timestamps(); 19 | $table->boolean('headings')->nullable(); 20 | $table->boolean('text')->nullable(); 21 | $table->boolean('lists')->nullable(); 22 | $table->boolean('blockquote')->nullable(); 23 | $table->boolean('rule')->nullable(); 24 | $table->boolean('table')->nullable(); 25 | $table->boolean('breadcrumbs')->nullable(); 26 | $table->boolean('forms')->nullable(); 27 | $table->boolean('buttons')->nullable(); 28 | }); 29 | } 30 | 31 | /** 32 | * Reverse the migrations. 33 | * 34 | * @return void 35 | */ 36 | public function down() 37 | { 38 | Schema::dropIfExists('styleguide_basics'); 39 | } 40 | } 41 | -------------------------------------------------------------------------------- /database/seeds/StyleguideBasicsSeeder.php: -------------------------------------------------------------------------------- 1 | create(); 16 | } 17 | } 18 | -------------------------------------------------------------------------------- /database/seeds/StyleguideColorSeeder.php: -------------------------------------------------------------------------------- 1 | create(); 16 | } 17 | } 18 | -------------------------------------------------------------------------------- /database/seeds/StyleguidePatternSeeder.php: -------------------------------------------------------------------------------- 1 | create(); 16 | } 17 | } 18 | -------------------------------------------------------------------------------- /mix-manifest.json: -------------------------------------------------------------------------------- 1 | { 2 | "/public/js/styleguide.js": "/public/js/styleguide.js", 3 | "/public/css/styleguide.css": "/public/css/styleguide.css", 4 | "/public/js/styleguide.js.map": "/public/js/styleguide.js.map" 5 | } 6 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "private": true, 3 | "scripts": { 4 | "development": "cross-env NODE_ENV=development node_modules/webpack/bin/webpack.js --progress --hide-modules --config=node_modules/laravel-mix/setup/webpack.config.js", 5 | "production": "cross-env NODE_ENV=production node_modules/webpack/bin/webpack.js --no-progress --hide-modules --config=node_modules/laravel-mix/setup/webpack.config.js" 6 | }, 7 | "devDependencies": { 8 | "axios": "^0.19", 9 | "cross-env": "^7.0", 10 | "laravel-mix": "^5.0.1", 11 | "lodash": "^4.17.13", 12 | "resolve-url-loader": "^3.1.0", 13 | "sass": "^1.15.2", 14 | "sass-loader": "^8.0.0", 15 | "vue-template-compiler": "^2.6.11" 16 | }, 17 | "browserslist": [ 18 | "last 2 versions", 19 | "ie >= 9" 20 | ] 21 | } 22 | -------------------------------------------------------------------------------- /public/css/styleguide.css: -------------------------------------------------------------------------------- 1 | .simple-styleguide--site-styles{width:90%;max-width:1030px;margin-left:auto;margin-right:auto}.simple-styleguide--site-styles h3.simple-styleguide--sectionhead{padding:20px 20px 12px 0;margin:80px 0 10px;color:#000;font-size:1.2rem;position:relative;border-bottom:4px solid #000;border-top:1px solid #000;text-transform:uppercase}.simple-styleguide--site-styles h3.simple-styleguide--sectionhead.first{margin-top:20px}.simple-styleguide--site-styles .simple-styleguide{margin:40px 0}.simple-styleguide--site-styles .simple-styleguide:after{content:"";display:block;clear:both}.simple-styleguide--site-styles .label{background:#ccc}.simple-styleguide--site-styles .simple-styleguide code{display:block;background:#eee;padding:10px;margin-top:20px;color:#9e9e9e;line-height:1.5}.simple-styleguide--jump-nav{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;margin:5px 0 0}.simple-styleguide--jump-nav li{list-style:none;margin:0 0 10px;padding:0;width:100%}@media (min-width:480px){.simple-styleguide--jump-nav li{width:50%}}@media (min-width:600px){.simple-styleguide--jump-nav li{width:25%}}.simple-styleguide--view-sourecode{cursor:pointer}.simple-styleguide pre{background:#f1f1f1;padding:20px;border:solid #fff;border-width:1px 1px 4px;margin:0;color:#9e9e9e}.simple-styleguide pre.active{display:block}.simple-styleguide--pattern{margin-top:20px}.simple-styleguide--colors{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap}.simple-styleguide--color{margin-right:2%;margin-bottom:15px;width:48%}.simple-styleguide--color:nth-child(2n){margin-right:0}@media (min-width:600px){.simple-styleguide--color{margin-right:2%;margin-bottom:15px;width:23%}.simple-styleguide--color:nth-child(2n){margin-right:2%}.simple-styleguide--color:nth-child(4n){margin-right:0}}.simple-styleguide--color--swatch--class,.simple-styleguide--color--swatch--usage,.simple-styleguide--color--swatch--values{display:block;font-size:10px;font-family:sans-serif}.simple-styleguide--color--swatch--usage{border-top:1px solid #9e9e9e;padding-top:5px;margin-top:5px}.simple-styleguide--color--swatch--class label,.simple-styleguide--color--swatch--values label,.simple-styleguide--color--swatch label{display:inline;font-weight:700;padding:0}.simple-styleguide--color--swatch{padding:4%;background:#fff}.simple-styleguide--site-styles .simple-styleguide--color--block{width:100%;height:100px;border:1px solid #fff}.simple-styleguide .calculate .info{display:block;font-size:10px;font-family:sans-serif}.simple-styleguide .calculate .info label{font-weight:700;display:inline} -------------------------------------------------------------------------------- /public/js/styleguide.js: -------------------------------------------------------------------------------- 1 | function _typeof(e){return(_typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}!function(e){var t={};function n(o){if(t[o])return t[o].exports;var r=t[o]={i:o,l:!1,exports:{}};return e[o].call(r.exports,r,r.exports,n),r.l=!0,r.exports}n.m=e,n.c=t,n.d=function(e,t,o){n.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:o})},n.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},n.t=function(e,t){if(1&t&&(e=n(e)),8&t)return e;if(4&t&&"object"==_typeof(e)&&e&&e.__esModule)return e;var o=Object.create(null);if(n.r(o),Object.defineProperty(o,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var r in e)n.d(o,r,function(t){return e[t]}.bind(null,r));return o},n.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return n.d(t,"a",t),t},n.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},n.p="/",n(n.s=0)}([function(e,t,n){n(1),e.exports=n(2)},function(e,t){var n=document.querySelectorAll(".simple-styleguide--view-sourecode");[].forEach.call(n,function(e){e.addEventListener("click",function(){e.nextElementSibling.classList.toggle("active")})});var o=document.querySelectorAll(".calculate");[].forEach.call(o,function(e){var t=e.querySelector(".measure"),n=e.querySelector(".info"),o=" ".concat(window.getComputedStyle(t).lineHeight),r=" ".concat(window.getComputedStyle(t).fontSize),l=" ".concat(window.getComputedStyle(t).marginBottom,"\n ").concat(window.getComputedStyle(t).marginRight," ").concat(window.getComputedStyle(t).marginBottom," ").concat(window.getComputedStyle(t).marginLeft);n.innerHTML="".concat(r,"
").concat(o,"
").concat(l)})},function(e,t){}]); 2 | -------------------------------------------------------------------------------- /public/js/styleguide.js.map: -------------------------------------------------------------------------------- 1 | {"version":3,"sources":["webpack:///webpack/bootstrap","webpack:///./resources/js/styleguide.js"],"names":["installedModules","__webpack_require__","moduleId","exports","module","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","viewSourceLinks","document","querySelectorAll","forEach","el","addEventListener","nextElementSibling","classList","toggle","calculableElements","measuredElement","querySelector","info","lineHeight","window","getComputedStyle","fontSize","margins","marginBottom","marginRight","marginLeft","innerHTML"],"mappings":"aACE,IAAIA,EAAmB,GAGvB,SAASC,EAAoBC,GAG5B,GAAGF,EAAiBE,GACnB,OAAOF,EAAiBE,GAAUC,QAGnC,IAAIC,EAASJ,EAAiBE,GAAY,CACzCG,EAAGH,EACHI,GAAG,EACHH,QAAS,IAUV,OANAI,EAAQL,GAAUM,KAAKJ,EAAOD,QAASC,EAAQA,EAAOD,QAASF,GAG/DG,EAAOE,GAAI,EAGJF,EAAOD,QAKfF,EAAoBQ,EAAIF,EAGxBN,EAAoBS,EAAIV,EAGxBC,EAAoBU,EAAI,SAASR,EAASS,EAAMC,GAC3CZ,EAAoBa,EAAEX,EAASS,IAClCG,OAAOC,eAAeb,EAASS,EAAM,CAAEK,YAAY,EAAMC,IAAKL,KAKhEZ,EAAoBkB,EAAI,SAAShB,GACX,oBAAXiB,QAA0BA,OAAOC,aAC1CN,OAAOC,eAAeb,EAASiB,OAAOC,YAAa,CAAEC,MAAO,WAE7DP,OAAOC,eAAeb,EAAS,aAAc,CAAEmB,OAAO,KAQvDrB,EAAoBsB,EAAI,SAASD,EAAOE,GAEvC,GADU,EAAPA,IAAUF,EAAQrB,EAAoBqB,IAC/B,EAAPE,EAAU,OAAOF,EACpB,GAAW,EAAPE,GAA8B,iBAAVF,GAAsBA,GAASA,EAAMG,WAAY,OAAOH,EAChF,IAAII,EAAKX,OAAOY,OAAO,MAGvB,GAFA1B,EAAoBkB,EAAEO,GACtBX,OAAOC,eAAeU,EAAI,UAAW,CAAET,YAAY,EAAMK,MAAOA,IACtD,EAAPE,GAA4B,iBAATF,EAAmB,IAAI,IAAIM,KAAON,EAAOrB,EAAoBU,EAAEe,EAAIE,EAAK,SAASA,GAAO,OAAON,EAAMM,IAAQC,KAAK,KAAMD,IAC9I,OAAOF,GAIRzB,EAAoB6B,EAAI,SAAS1B,GAChC,IAAIS,EAAST,GAAUA,EAAOqB,WAC7B,WAAwB,OAAOrB,EAAgB,SAC/C,WAA8B,OAAOA,GAEtC,OADAH,EAAoBU,EAAEE,EAAQ,IAAKA,GAC5BA,GAIRZ,EAAoBa,EAAI,SAASiB,EAAQC,GAAY,OAAOjB,OAAOkB,UAAUC,eAAe1B,KAAKuB,EAAQC,IAGzG/B,EAAoBkC,EAAI,IAIjBlC,EAAoBA,EAAoBmC,EAAI,G,qDC5ErD,IAAMC,EAAkBC,SAASC,iBAC7B,sCAGJ,GAAGC,QAAQhC,KAAK6B,GAAiB,SAAAI,GAC7BA,EAAGC,iBAAiB,SAAS,WACzBD,EAAGE,mBAAmBC,UAAUC,OAAO,gBAI/C,IAAMC,EAAqBR,SAASC,iBAAiB,cAErD,GAAGC,QAAQhC,KAAKsC,GAAoB,SAAAL,GAChC,IAAMM,EAAkBN,EAAGO,cAAc,YACnCC,EAAOR,EAAGO,cAAc,SACxBE,EAAa,+BAAH,OACZC,OAAOC,iBAAiBL,GAAiBG,YAEvCG,EAAW,6BAAH,OACVF,OAAOC,iBAAiBL,GAAiBM,UAEvCC,EAAU,0BAAH,OACTH,OAAOC,iBAAiBL,GAAiBQ,aADhC,qBAGPJ,OAAOC,iBAAiBL,GAAiBS,YAHlC,YAITL,OAAOC,iBAAiBL,GAAiBQ,aAJhC,YAKTJ,OAAOC,iBAAiBL,GAAiBU,YAE7CR,EAAKS,UAAL,UAAoBL,EAApB,gBAAoCH,EAApC,gBAAsDI,O","file":"/public/js/styleguide.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"/\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 0);\n","/**\n * @file\n * Simple styleguide javascript.\n *\n */\n\nconst viewSourceLinks = document.querySelectorAll(\n '.simple-styleguide--view-sourecode'\n);\n\n[].forEach.call(viewSourceLinks, el => {\n el.addEventListener('click', () => {\n el.nextElementSibling.classList.toggle('active');\n });\n});\n\nconst calculableElements = document.querySelectorAll('.calculate');\n\n[].forEach.call(calculableElements, el => {\n const measuredElement = el.querySelector('.measure');\n const info = el.querySelector('.info');\n const lineHeight = ` ${\n window.getComputedStyle(measuredElement).lineHeight\n }`;\n const fontSize = ` ${\n window.getComputedStyle(measuredElement).fontSize\n }`;\n const margins = ` ${\n window.getComputedStyle(measuredElement).marginBottom\n }\n ${window.getComputedStyle(measuredElement).marginRight} ${\n window.getComputedStyle(measuredElement).marginBottom\n } ${window.getComputedStyle(measuredElement).marginLeft}`;\n\n info.innerHTML = `${fontSize}
${lineHeight}
${margins}`;\n});\n\n"],"sourceRoot":""} -------------------------------------------------------------------------------- /resources/js/styleguide.js: -------------------------------------------------------------------------------- 1 | /** 2 | * @file 3 | * Simple styleguide javascript. 4 | * 5 | */ 6 | 7 | const viewSourceLinks = document.querySelectorAll( 8 | '.simple-styleguide--view-sourecode' 9 | ); 10 | 11 | [].forEach.call(viewSourceLinks, el => { 12 | el.addEventListener('click', () => { 13 | el.nextElementSibling.classList.toggle('active'); 14 | }); 15 | }); 16 | 17 | const calculableElements = document.querySelectorAll('.calculate'); 18 | 19 | [].forEach.call(calculableElements, el => { 20 | const measuredElement = el.querySelector('.measure'); 21 | const info = el.querySelector('.info'); 22 | const lineHeight = ` ${ 23 | window.getComputedStyle(measuredElement).lineHeight 24 | }`; 25 | const fontSize = ` ${ 26 | window.getComputedStyle(measuredElement).fontSize 27 | }`; 28 | const margins = ` ${ 29 | window.getComputedStyle(measuredElement).marginBottom 30 | } 31 | ${window.getComputedStyle(measuredElement).marginRight} ${ 32 | window.getComputedStyle(measuredElement).marginBottom 33 | } ${window.getComputedStyle(measuredElement).marginLeft}`; 34 | 35 | info.innerHTML = `${fontSize}
${lineHeight}
${margins}`; 36 | }); 37 | 38 | -------------------------------------------------------------------------------- /resources/sass/styleguide.scss: -------------------------------------------------------------------------------- 1 | .simple-styleguide--site-styles { 2 | width: 90%; 3 | max-width: 1030px; 4 | margin-left: auto; 5 | margin-right: auto; 6 | } 7 | .simple-styleguide--site-styles h3.simple-styleguide--sectionhead { 8 | padding: 20px 20px 12px 0; 9 | margin: 80px 0 10px 0; 10 | color: #000; 11 | font-size: 1.2rem; 12 | position: relative; 13 | border-bottom: 4px solid #000; 14 | border-top: 1px solid #000; 15 | text-transform: uppercase; 16 | } 17 | .simple-styleguide--site-styles h3.simple-styleguide--sectionhead.first { 18 | margin-top: 20px; 19 | } 20 | .simple-styleguide--site-styles .simple-styleguide { 21 | margin: 40px 0; 22 | } 23 | .simple-styleguide--site-styles .simple-styleguide:after { 24 | content: ""; 25 | display: block; 26 | clear: both; 27 | } 28 | .simple-styleguide--site-styles .label { 29 | background: #ccc; 30 | } 31 | .simple-styleguide--site-styles .simple-styleguide code { 32 | display: block; 33 | background: #eee; 34 | padding: 10px; 35 | margin-top: 20px; 36 | color: #9e9e9e; 37 | line-height: 1.5; 38 | } 39 | 40 | .simple-styleguide--jump-nav { 41 | display: flex; 42 | flex-wrap: wrap; 43 | margin: 5px 0 0 0; 44 | } 45 | 46 | .simple-styleguide--jump-nav li { 47 | list-style: none; 48 | margin: 0 0 10px 0; 49 | padding: 0; 50 | width: 100%; 51 | } 52 | 53 | @media (min-width: 480px) { 54 | .simple-styleguide--jump-nav li { 55 | width: 50%; 56 | } 57 | } 58 | 59 | @media (min-width: 600px) { 60 | .simple-styleguide--jump-nav li { 61 | width: 25%; 62 | } 63 | } 64 | 65 | .simple-styleguide--view-sourecode { 66 | cursor: pointer; 67 | } 68 | 69 | .simple-styleguide pre { 70 | background: #f1f1f1; 71 | padding: 20px; 72 | border: 1px solid #fff; 73 | border-bottom: 4px solid #fff; 74 | margin: 0; 75 | color: #9e9e9e; 76 | } 77 | 78 | .simple-styleguide pre.active { 79 | display: block; 80 | } 81 | 82 | .simple-styleguide--pattern { 83 | margin-top: 20px; 84 | } 85 | 86 | .simple-styleguide--colors { 87 | display: flex; 88 | flex-wrap: wrap; 89 | } 90 | 91 | .simple-styleguide--color { 92 | /*border: 1px solid #d3d3d3;*/ 93 | margin-right: 2%; 94 | margin-bottom: 15px; 95 | width: 48%; 96 | } 97 | 98 | .simple-styleguide--color:nth-child(2n) { 99 | margin-right: 0; 100 | } 101 | 102 | @media (min-width: 600px) { 103 | .simple-styleguide--color { 104 | margin-right: 2%; 105 | margin-bottom: 15px; 106 | width: 23%; 107 | } 108 | .simple-styleguide--color:nth-child(2n) { 109 | margin-right: 2%; 110 | } 111 | .simple-styleguide--color:nth-child(4n) { 112 | margin-right: 0; 113 | } 114 | } 115 | 116 | 117 | .simple-styleguide--color--swatch--class, 118 | .simple-styleguide--color--swatch--values, 119 | .simple-styleguide--color--swatch--usage { 120 | display: block; 121 | font-size: 10px; 122 | font-family: sans-serif; 123 | } 124 | 125 | .simple-styleguide--color--swatch--usage { 126 | border-top: 1px solid #9e9e9e; 127 | padding-top: 5px; 128 | margin-top: 5px; 129 | } 130 | 131 | .simple-styleguide--color--swatch--class label, 132 | .simple-styleguide--color--swatch--values label, 133 | .simple-styleguide--color--swatch label { 134 | display: inline; 135 | font-weight: bold; 136 | padding: 0; 137 | } 138 | 139 | .simple-styleguide--color--swatch { 140 | padding: 4%; 141 | background: #fff; 142 | } 143 | 144 | .simple-styleguide--site-styles .simple-styleguide--color--block { 145 | width: 100%; 146 | height: 100px; 147 | border: 1px solid #fff; 148 | } 149 | 150 | .simple-styleguide .calculate .info { 151 | display: block; 152 | font-size: 10px; 153 | font-family: sans-serif; 154 | } 155 | 156 | .simple-styleguide .calculate .info label { 157 | font-weight: bold; 158 | display: inline; 159 | } 160 | -------------------------------------------------------------------------------- /resources/views/basics/edit.blade.php: -------------------------------------------------------------------------------- 1 | @extends('styleguide::layout') 2 | 3 | @section('content') 4 | 9 |

Edit Basic Settings

10 |
11 |
12 | Styleguide Basic Settings 13 |
14 |
15 | @if ($errors->any()) 16 |
17 |
    18 | @foreach ($errors->all() as $error) 19 |
  • {{ $error }}
  • 20 | @endforeach 21 |
22 |

23 | @endif 24 | 25 | @isset($basics) 26 |
27 | @csrf 28 | @method('PATCH') 29 | 30 |
31 | @foreach($fillable as $value) 32 |
33 | @if($basics->$value) 34 | 35 | @else 36 | 37 | @endif 38 | 39 | 40 |
41 | @endforeach 42 |
43 | 44 | 45 |
46 | @else 47 |
48 | @csrf 49 | 50 |
51 | @foreach($fillable as $value) 52 |
53 | 54 | 55 |
56 | @endforeach 57 |
58 | 59 | 60 |
61 | @endif 62 | 63 |
64 |
65 | @endsection 66 | -------------------------------------------------------------------------------- /resources/views/basics/list.blade.php: -------------------------------------------------------------------------------- 1 | @extends('styleguide::layout') 2 | 3 | @section('content') 4 | 9 |

Basic Settings

10 |
11 | @if(count($basics)) 12 | You have settings. 13 | Edit Settings 14 | @else 15 | You don't have any basic settings yet. 16 | Create Settings 17 | @endif 18 |
19 | @endsection 20 | -------------------------------------------------------------------------------- /resources/views/codemirror.blade.php: -------------------------------------------------------------------------------- 1 | {{--CodeMirror Scripts and Styles.--}} 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 21 | -------------------------------------------------------------------------------- /resources/views/colors/create.blade.php: -------------------------------------------------------------------------------- 1 | @extends('styleguide::layout') 2 | 3 | @section('content') 4 | 9 |

Add Color

10 |
11 |
12 | @if ($errors->any()) 13 |
14 |
    15 | @foreach ($errors->all() as $error) 16 |
  • {{ $error }}
  • 17 | @endforeach 18 |
19 |

20 | @endif 21 |
22 |
23 | @csrf 24 | 25 | 26 |
27 |
28 | 29 | 30 |
31 |
32 | 33 | 34 |
35 | 36 |
37 |
38 |
39 | @endsection 40 | -------------------------------------------------------------------------------- /resources/views/colors/edit.blade.php: -------------------------------------------------------------------------------- 1 | @extends('styleguide::layout') 2 | 3 | @section('content') 4 | 9 |

Edit Color

10 |
11 |
12 | @if ($errors->any()) 13 |
14 |
    15 | @foreach ($errors->all() as $error) 16 |
  • {{ $error }}
  • 17 | @endforeach 18 |
19 |

20 | @endif 21 |
22 |
23 | @csrf 24 | @method('PATCH') 25 | 26 | 27 |
28 |
29 | 30 | 31 |
32 |
33 | 34 | 35 |
36 |
37 |
38 |
39 | 40 |
41 |
42 |
43 | @endsection 44 | -------------------------------------------------------------------------------- /resources/views/colors/list.blade.php: -------------------------------------------------------------------------------- 1 | @extends('styleguide::layout') 2 | 3 | @section('content') 4 | 9 |

Colors

10 |
11 | @if(session()->get('success')) 12 |
13 | {{ session()->get('success') }} 14 |

15 | @endif 16 | 17 |
18 | Add color 19 |
20 | 21 | @if(!$colors->isEmpty()) 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 | 33 | 34 | @foreach($colors as $color) 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42 | 49 | 50 | @endforeach 51 | 52 |
IDClassDescriptionColorPreviewAction
{{$color->id}}{{$color->class}}{!! $color->description !!}{{$color->hex}} Edit 43 |
44 | @csrf 45 | @method('DELETE') 46 | 47 |
48 |
53 | @endif 54 |
55 | @endsection 56 | -------------------------------------------------------------------------------- /resources/views/components/base-error.blade.php: -------------------------------------------------------------------------------- 1 | 7 | -------------------------------------------------------------------------------- /resources/views/components/base.blade.php: -------------------------------------------------------------------------------- 1 |
2 |
3 |
4 | @if($basics) 5 | Default patterns: 6 |
    7 | @if($basics->headings) 8 |
  • headings
  • 9 | @endif 10 | 11 | @if($basics->text) 12 |
  • text
  • 13 | @endif 14 | 15 | @if($basics->lists) 16 |
  • lists
  • 17 | @endif 18 | 19 | @if($basics->blockquote) 20 |
  • blockquote
  • 21 | @endif 22 | 23 | @if($basics->rule) 24 |
  • rule
  • 25 | @endif 26 | 27 | @if($basics->table) 28 |
  • table
  • 29 | @endif 30 | 31 | @if($basics->breadcrumbs) 32 |
  • breadcrumbs
  • 33 | @endif 34 | 35 | @if($basics->forms) 36 |
  • forms
  • 37 | @endif 38 | 39 | @if($basics->buttons) 40 |
  • buttons
  • 41 | @endif 42 |
43 | @endif 44 | 45 | @if($patterns) 46 | Custom patterns: 47 | 52 | @endif 53 |
54 |
55 | 56 | {{--========================================================================================================--}} 57 | {{--========================================================================================================--}} 58 | {{--========================================================================================================--}} 59 | 60 |
61 | @if($colors) 62 | 63 |

styleguide colors

64 |
65 |
66 | @foreach($colors as $color) 67 |
68 |
69 |
70 | {{$color['class']}} 71 | {{$color['hex']}} | rgb({{$color['rgb']}}) 72 | {!! $color['description'] !!} 73 |
74 |
75 | @endforeach 76 |
77 |
78 | @endif 79 | 80 | {{--========================================================================================================--}} 81 | {{--========================================================================================================--}} 82 | {{--========================================================================================================--}} 83 | 84 | @if(!empty($basics)) 85 | @if($basics->headings) 86 | 87 |

headings

88 |
89 |
90 |

H1 Heading

91 |

H1 Heading With
Broken Text

92 |

H1 Heading With Linked Text

93 | 94 |
95 |
96 |
97 |

H2 Heading

98 |

H2 Heading With
Broken Text

99 |

H2 Heading With Linked Text

100 | 101 |
102 |
103 |
104 |

H3 Heading

105 |

H3 Heading With
Broken Text

106 |

H3 Heading With Linked Text

107 | 108 |
109 |
110 |
111 |

H4 Heading

112 |

H4 Heading With
Broken Text

113 |

H4 Heading With Linked Text

114 | 115 |
116 |
117 |
118 |
H5 Heading
119 |
H5 Heading With
Broken Text
120 |
H5 Heading With Linked Text
121 | 122 |
123 |
124 |
125 |
H6 Heading
126 |
H6 Heading With
Broken Text
127 |
H6 Heading With Linked Text
128 | 129 |
130 |
131 |
132 |
133 |

H1 Heading

134 |

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aliquam iaculis, velit gravida convallis 135 | tincidunt, felis enim venenatis lorem, nec lobortis nisl urna et mi. Pellentesque ac dictum ante. 136 | Fusce dignissim tempor elementum. Ut dignissim convallis eros, viverra luctus lacus consequat ac. 137 | Sed feugiat velit sed magna aliquam accumsan. Nam vitae porta tortor. Nam auctor dui a neque iaculis 138 | in aliquam erat viverra. Duis orci nunc, lacinia in malesuada et, euismod id turpis. Cras mattis 139 | vulputate erat, eget tempor magna egestas eu. Vestibulum sit amet massa est.

140 |

H2 Heading

141 |

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aliquam iaculis, velit gravida convallis 142 | tincidunt, felis enim venenatis lorem, nec lobortis nisl urna et mi. Pellentesque ac dictum ante. 143 | Fusce dignissim tempor elementum. Ut dignissim convallis eros, viverra luctus lacus consequat ac. 144 | Sed feugiat velit sed magna aliquam accumsan. Nam vitae porta tortor. Nam auctor dui a neque iaculis 145 | in aliquam erat viverra. Duis orci nunc, lacinia in malesuada et, euismod id turpis. Cras mattis 146 | vulputate erat, eget tempor magna egestas eu. Vestibulum sit amet massa est.

147 |

H3 Heading

148 |

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aliquam iaculis, velit gravida convallis 149 | tincidunt, felis enim venenatis lorem, nec lobortis nisl urna et mi. Pellentesque ac dictum ante. 150 | Fusce dignissim tempor elementum. Ut dignissim convallis eros, viverra luctus lacus consequat ac. 151 | Sed feugiat velit sed magna aliquam accumsan. Nam vitae porta tortor. Nam auctor dui a neque iaculis 152 | in aliquam erat viverra. Duis orci nunc, lacinia in malesuada et, euismod id turpis. Cras mattis 153 | vulputate erat, eget tempor magna egestas eu. Vestibulum sit amet massa est.

154 |

H4 Heading

155 |

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aliquam iaculis, velit gravida convallis 156 | tincidunt, felis enim venenatis lorem, nec lobortis nisl urna et mi. Pellentesque ac dictum ante. 157 | Fusce dignissim tempor elementum. Ut dignissim convallis eros, viverra luctus lacus consequat ac. 158 | Sed feugiat velit sed magna aliquam accumsan. Nam vitae porta tortor. Nam auctor dui a neque iaculis 159 | in aliquam erat viverra. Duis orci nunc, lacinia in malesuada et, euismod id turpis. Cras mattis 160 | vulputate erat, eget tempor magna egestas eu. Vestibulum sit amet massa est.

161 |
H5 Heading
162 |

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aliquam iaculis, velit gravida convallis 163 | tincidunt, felis enim venenatis lorem, nec lobortis nisl urna et mi. Pellentesque ac dictum ante. 164 | Fusce dignissim tempor elementum. Ut dignissim convallis eros, viverra luctus lacus consequat ac. 165 | Sed feugiat velit sed magna aliquam accumsan. Nam vitae porta tortor. Nam auctor dui a neque iaculis 166 | in aliquam erat viverra. Duis orci nunc, lacinia in malesuada et, euismod id turpis. Cras mattis 167 | vulputate erat, eget tempor magna egestas eu. Vestibulum sit amet massa est.

168 |
H6 Heading
169 |

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aliquam iaculis, velit gravida convallis 170 | tincidunt, felis enim venenatis lorem, nec lobortis nisl urna et mi. Pellentesque ac dictum ante. 171 | Fusce dignissim tempor elementum. Ut dignissim convallis eros, viverra luctus lacus consequat ac. 172 | Sed feugiat velit sed magna aliquam accumsan. Nam vitae porta tortor. Nam auctor dui a neque iaculis 173 | in aliquam erat viverra. Duis orci nunc, lacinia in malesuada et, euismod id turpis. Cras mattis 174 | vulputate erat, eget tempor magna egestas eu. Vestibulum sit amet massa est.

175 |
176 | @endif 177 | 178 | @if($basics->text) 179 | 180 |

text

181 |
182 |

Normal text:
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aliquam 183 | iaculis, velit gravida convallis tincidunt, felis enim venenatis lorem, nec lobortis nisl urna et 184 | mi. Pellentesque ac dictum ante. Fusce dignissim tempor elementum. Ut dignissim convallis eros, 185 | viverra luctus lacus consequat ac. Sed feugiat velit sed magna aliquam accumsan. Nam vitae porta 186 | tortor. Nam auctor dui a neque iaculis in aliquam erat viverra. Duis orci nunc, lacinia in malesuada 187 | et, euismod id turpis. Cras mattis vulputate erat, eget tempor magna egestas eu. Vestibulum sit amet 188 | massa est.

189 |

Vivamus pretium placerat lorem, in tempor massa convallis sit amet. Aliquam sed quam eget ligula 190 | luctus aliquam sed vitae nulla. Aliquam dui dolor, ullamcorper eget rutrum ut, hendrerit ac lorem. 191 | Donec magna est, sollicitudin vel ultrices vel, mattis ut odio. Integer vel felis laoreet purus 192 | sollicitudin varius sed id ipsum. Suspendisse potenti. Praesent ut justo vitae metus luctus vehicula 193 | a et purus. Suspendisse potenti. Sed viverra, quam non hendrerit laoreet, massa odio blandit arcu, 194 | ac molestie metus diam eu tortor. Donec erat arcu, ultrices sit amet placerat non, feugiat in arcu. 195 | Mauris eros quam, varius eget volutpat vel, tristique sed est. In faucibus feugiat urna sit amet 196 | elementum. Integer consequat rhoncus libero, in molestie augue posuere et. Phasellus ac eleifend 197 | magna. Proin vulputate dui ac justo pharetra consequat. In vel iaculis ligula.

198 |

Cras vestibulum lacus sit amet sem commodo ullamcorper aliquet eros vestibulum. Sed fermentum nulla 199 | quis risus suscipit dapibus. Sed vitae velit ut dolor varius semper at id lectus. Aenean quis leo 200 | sit amet tellus tempus cursus. Vivamus semper vehicula ante eget semper. In ac ipsum erat. 201 | Suspendisse lectus erat, commodo nec fringilla quis, interdum non leo. Vivamus et lectus vitae risus 202 | porta sollicitudin luctus eget est. Etiam quis elit vel est suscipit tristique. Nullam fringilla 203 | purus ac velit gravida ullamcorper. Praesent porttitor ante non lacus suscipit porta. Nunc fermentum 204 | sem et metus aliquam ultricies non sollicitudin nibh. Vestibulum ut ligula dolor, in placerat 205 | tortor. Sed nec lacus sed nibh iaculis luctus. Pellentesque habitant morbi tristique senectus et 206 | netus et malesuada fames ac turpis egestas. Curabitur rutrum, diam vel tempor commodo, augue nunc 207 | viverra risus, in pellentesque neque justo eget dolor. Maecenas quis odio leo, a auctor lorem.

208 |

Link:
This is an example of a link within copy. Lorem ipsum 209 | dolor sit amet, consectetur adipiscing elit. Aliquam iaculis, velit gravida convallis tincidunt, 210 | felis enim venenatis lorem, nec lobortis nisl urna et mi.

211 |

Strong:
This is an example of strong text within copy. Lorem 212 | ipsum bold text, consectetur adipiscing elit. Aliquam iaculis, velit gravida convallis 213 | tincidunt, felis enim venenatis lorem, nec lobortis nisl urna et mi.

214 |

Emphasis:
This is an example of emphasis placed on text within copy. 215 | Lorem ipsum dolor sit italic text, consectetur adipiscing elit. Aliquam iaculis, velit 216 | gravida convallis tincidunt, felis enim venenatis lorem, nec lobortis nisl urna et mi.

217 |

Superscript/Subscript:
This is an example of superscript2 text and 218 | subscript2 text. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aliquam 219 | iaculis, velit gravida convallis tincidunt, felis enim venenatis lorem, nec lobortis nisl urna et 220 | mi. Aliquam iaculis, velit gravida convallis tincidunt, felis enim venenatis lorem, nec 221 | lobortis2 nisl urna et mi. Aliquam iaculis, velit gravida convallis2 222 | tincidunt, felis enim venenatis lorem, nec lobortis nisl urna et mi. Aliquam iaculis, velit gravida 223 | convallis tincidunt, felis enim venenatis lorem, nec lobortis nisl urna et mi. Aliquam iaculis, 224 | velit gravida convallis tincidunt, felis enim venenatis lorem, nec lobortis nisl urna et mi.

225 |

Small:
This is an example of small text within copy. Lorem ipsum 226 | dolor sit amet, consectetur adipiscing elit. Aliquam iaculis, velit gravida convallis tincidunt, 227 | felis enim venenatis lorem, nec lobortis nisl urna et mi.

228 |

Link:
This is an example of a link within copy. Lorem ipsum 229 | dolor sit amet, consectetur adipiscing elit. Aliquam iaculis, velit gravida convallis tincidunt, 230 | felis enim venenatis lorem, nec lobortis nisl urna et mi.

231 |

Underline:
This is an example of underlined text within copy. Lorem ipsum 232 | dolor sit amet, consectetur adipiscing elit. Aliquam iaculis, velit gravida convallis tincidunt, 233 | felis enim venenatis lorem, nec lobortis nisl urna et mi.

234 |

Delete:
This is an 235 | example of deleted text 236 | within copy. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aliquam iaculis, velit gravida 237 | convallis tincidunt, felis enim venenatis lorem, nec lobortis nisl urna et mi. 238 |

239 |
240 | @endif 241 | 242 | @if($basics->lists) 243 | 244 |

lists

245 |
246 |
247 |

Unordered List:

248 |

Donec sed odio dui. Duis mollis, est non commodo luctus, nisi erat porttitor ligula, eget lacinia 249 | odio sem nec elit. Sed posuere consectetur est at lobortis. Vivamus sagittis lacus vel augue 250 | laoreet rutrum faucibus dolor auctor. Donec sed odio dui. Maecenas sed diam eget risus varius 251 | blandit sit amet non magna.

252 |
    253 |
  • lacinia
  • 254 |
  • Vestibulum id ligula porta felis euismod semper. Maecenas sed diam eget risus varius blandit 255 | sit amet non magna. Praesent commodo cursus magna, vel scelerisque nisl consectetur et. Sed 256 | posuere consectetur est at lobortis. Cum sociis natoque penatibus et magnis dis parturient 257 | montes, nascetur ridiculus mus. Aenean lacinia bibendum nulla sed consectetur. 258 |
  • 259 |
  • lobortis
  • 260 |
  • lobortis
  • 261 |
  • erat
  • 262 |
263 |

Donec sed odio dui. Duis mollis, est non commodo luctus, nisi erat porttitor ligula, eget lacinia 264 | odio sem nec elit. Sed posuere consectetur est at lobortis. Vivamus sagittis lacus vel augue 265 | laoreet rutrum faucibus dolor auctor. Donec sed odio dui. Maecenas sed diam eget risus varius 266 | blandit sit amet non magna.

267 |
268 |
269 |

Ordered List:

270 |

Donec sed odio dui. Duis mollis, est non commodo luctus, nisi erat porttitor ligula, eget lacinia 271 | odio sem nec elit. Sed posuere consectetur est at lobortis. Vivamus sagittis lacus vel augue 272 | laoreet rutrum faucibus dolor auctor. Donec sed odio dui. Maecenas sed diam eget risus varius 273 | blandit sit amet non magna.

274 |
    275 |
  1. erat
  2. 276 |
  3. eros
  4. 277 |
  5. iaculis
  6. 278 |
  7. in
  8. 279 |
  9. sed
  10. 280 |
281 |

Donec sed odio dui. Duis mollis, est non commodo luctus, nisi erat porttitor ligula, eget lacinia 282 | odio sem nec elit. Sed posuere consectetur est at lobortis. Vivamus sagittis lacus vel augue 283 | laoreet rutrum faucibus dolor auctor. Donec sed odio dui. Maecenas sed diam eget risus varius 284 | blandit sit amet non magna.

285 |
286 |
287 |

Nested Lists:

288 |

Nulla dui purus, eleifend vel, consequat non, dictum porta, nulla. Duis ante mi, laoreet ut, 289 | commodo eleifend, cursus nec, lorem. Aenean eu est. Etiam imperdiet turpis. Praesent nec augue. 290 | Curabitur ligula quam, rutrum id, tempor sed, consequat ac, dui. Vestibulum accumsan eros nec 291 | magna. Vestibulum vitae dui. Vestibulum nec ligula et lorem consequat ullamcorper. Class aptent 292 | taciti sociosqu ad litora torquent per conubia nostra, per inceptos hymenaeos. Phasellus eget 293 | nisl ut elit porta ullamcorper. Maecenas tincidunt velit quis orci. Sed in dui. Nullam ut mauris 294 | eu mi mollis luctus. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per 295 | inceptos hymenaeos. Sed cursus cursus velit. Sed a massa. Duis dignissim euismod quam. Nullam 296 | euismod metus ut orci. Vestibulum erat libero, scelerisque et, porttitor et, varius a, leo.

297 |
    298 |
  • Item One
  • 299 |
  • Item Two
  • 300 |
  • Item Three 301 |
      302 |
    • Nested Item One
    • 303 |
    • Nested Item Two
    • 304 |
    • Nested Item Three
    • 305 |
    306 |
  • 307 |
  • Item Four
  • 308 |
  • Item Five
  • 309 |
  • Item Six
  • 310 |
  • Item Seven 311 |
      312 |
    • Nested Item One
    • 313 |
    • Nested Item Two 314 |
        315 |
      • Double Nested Item One
      • 316 |
      • Double Nested Item Two
      • 317 |
      • Double Nested Item Three
      • 318 |
      319 |
    • 320 |
    • Nested Item Three
    • 321 |
    322 |
  • 323 |
  • Item Eight
  • 324 |
  • Item Nine
  • 325 |
  • Item Ten
  • 326 |
327 |

Nulla dui purus, eleifend vel, consequat non, dictum porta, nulla. Duis ante mi, laoreet ut, 328 | commodo eleifend, cursus nec, lorem. Aenean eu est. Etiam imperdiet turpis. Praesent nec augue. 329 | Curabitur ligula quam, rutrum id, tempor sed, consequat ac, dui. Vestibulum accumsan eros nec 330 | magna. Vestibulum vitae dui. Vestibulum nec ligula et lorem consequat ullamcorper. Class aptent 331 | taciti sociosqu ad litora torquent per conubia nostra, per inceptos hymenaeos. Phasellus eget 332 | nisl ut elit porta ullamcorper. Maecenas tincidunt velit quis orci. Sed in dui. Nullam ut mauris 333 | eu mi mollis luctus. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per 334 | inceptos hymenaeos. Sed cursus cursus velit. Sed a massa. Duis dignissim euismod quam. Nullam 335 | euismod metus ut orci. Vestibulum erat libero, scelerisque et, porttitor et, varius a, leo.

336 |
    337 |
  1. Item One
  2. 338 |
  3. Item Two
  4. 339 |
  5. Item Three 340 |
      341 |
    • Nested Item One
    • 342 |
    • Nested Item Two
    • 343 |
    • Nested Item Three
    • 344 |
    345 |
  6. 346 |
  7. Item Four
  8. 347 |
  9. Item Five
  10. 348 |
  11. Item Six
  12. 349 |
  13. Item Seven 350 |
      351 |
    • Nested Item One
    • 352 |
    • Nested Item Two 353 |
        354 |
      • Double Nested Item One
      • 355 |
      • Double Nested Item Two
      • 356 |
      • Double Nested Item Three
      • 357 |
      358 |
    • 359 |
    • Nested Item Three
    • 360 |
    361 |
  14. 362 |
  15. Item Eight
  16. 363 |
  17. Item Nine
  18. 364 |
  19. Item Ten
  20. 365 |
366 |

Nulla dui purus, eleifend vel, consequat non, dictum porta, nulla. Duis ante mi, laoreet ut, 367 | commodo eleifend, cursus nec, lorem. Aenean eu est. Etiam imperdiet turpis. Praesent nec augue. 368 | Curabitur ligula quam, rutrum id, tempor sed, consequat ac, dui. Vestibulum accumsan eros nec 369 | magna. Vestibulum vitae dui. Vestibulum nec ligula et lorem consequat ullamcorper. Class aptent 370 | taciti sociosqu ad litora torquent per conubia nostra, per inceptos hymenaeos. Phasellus eget 371 | nisl ut elit porta ullamcorper. Maecenas tincidunt velit quis orci. Sed in dui. Nullam ut mauris 372 | eu mi mollis luctus. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per 373 | inceptos hymenaeos. Sed cursus cursus velit. Sed a massa. Duis dignissim euismod quam. Nullam 374 | euismod metus ut orci. Vestibulum erat libero, scelerisque et, porttitor et, varius a, leo.

375 |
376 |
377 | @endif 378 | 379 | @if($basics->blockquote) 380 | 381 |

blockquote

382 |
383 |

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aliquam iaculis, velit gravida convallis 384 | tincidunt, felis enim venenatis lorem, nec lobortis nisl urna et mi. Pellentesque ac dictum ante. 385 | Fusce dignissim tempor elementum. Ut dignissim convallis eros, viverra luctus lacus consequat ac. 386 | Sed feugiat velit sed magna aliquam accumsan. Nam vitae porta tortor. Nam auctor dui a neque iaculis 387 | in aliquam erat viverra. Duis orci nunc, lacinia in malesuada et, euismod id turpis. Cras mattis 388 | vulputate erat, eget tempor magna egestas eu. Vestibulum sit amet massa est.

389 |
Aliquam sed quam eget ligula luctus aliquam sed vitae nulla. Aliquam dui dolor, ullamcorper 390 | eget rutrum ut, hendrerit ac lorem. Donec magna est, sollicitudin vel ultrices vel, mattis ut odio. 391 |
392 |

Vivamus pretium placerat lorem, in tempor massa convallis sit amet. Aliquam sed quam eget ligula 393 | luctus aliquam sed vitae nulla. Aliquam dui dolor, ullamcorper eget rutrum ut, hendrerit ac lorem. 394 | Donec magna est, sollicitudin vel ultrices vel, mattis ut odio. Integer vel felis laoreet purus 395 | sollicitudin varius sed id ipsum. Suspendisse potenti. Praesent ut justo vitae metus luctus vehicula 396 | a et purus. Suspendisse potenti. Sed viverra, quam non hendrerit laoreet, massa odio blandit arcu, 397 | ac molestie metus diam eu tortor. Donec erat arcu, ultrices sit amet placerat non, feugiat in arcu. 398 | Mauris eros quam, varius eget volutpat vel, tristique sed est. In faucibus feugiat urna sit amet 399 | elementum. Integer consequat rhoncus libero, in molestie augue posuere et. Phasellus ac eleifend 400 | magna. Proin vulputate dui ac justo pharetra consequat. In vel iaculis ligula.

401 |

Cras vestibulum lacus sit amet sem commodo ullamcorper aliquet eros vestibulum. Sed fermentum nulla 402 | quis risus suscipit dapibus. Sed vitae velit ut dolor varius semper at id lectus. Aenean quis leo 403 | sit amet tellus tempus cursus. Vivamus semper vehicula ante eget semper. In ac ipsum erat. 404 | Suspendisse lectus erat, commodo nec fringilla quis, interdum non leo. Vivamus et lectus vitae risus 405 | porta sollicitudin luctus eget est. Etiam quis elit vel est suscipit tristique. Nullam fringilla 406 | purus ac velit gravida ullamcorper. Praesent porttitor ante non lacus suscipit porta. Nunc fermentum 407 | sem et metus aliquam ultricies non sollicitudin nibh. Vestibulum ut ligula dolor, in placerat 408 | tortor. Sed nec lacus sed nibh iaculis luctus. Pellentesque habitant morbi tristique senectus et 409 | netus et malesuada fames ac turpis egestas. Curabitur rutrum, diam vel tempor commodo, augue nunc 410 | viverra risus, in pellentesque neque justo eget dolor. Maecenas quis odio leo, a auctor lorem.

411 |
412 | @endif 413 | 414 | @if($basics->rule) 415 | 416 |

rule

417 |
418 |

Nulla dui purus, eleifend vel, consequat non, dictum porta, nulla. Duis ante mi, laoreet ut, commodo 419 | eleifend, cursus nec, lorem. Aenean eu est. Etiam imperdiet turpis. Praesent nec augue. Curabitur 420 | ligula quam, rutrum id, tempor sed, consequat ac, dui. Vestibulum accumsan eros nec magna. 421 | Vestibulum vitae dui. Vestibulum nec ligula et lorem consequat ullamcorper. Class aptent taciti 422 | sociosqu ad litora torquent per conubia nostra, per inceptos hymenaeos. Phasellus eget nisl ut elit 423 | porta ullamcorper. Maecenas tincidunt velit quis orci. Sed in dui. Nullam ut mauris eu mi mollis 424 | luctus. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos hymenaeos. 425 | Sed cursus cursus velit. Sed a massa. Duis dignissim euismod quam. Nullam euismod metus ut orci. 426 | Vestibulum erat libero, scelerisque et, porttitor et, varius a, leo.

427 |
428 |

Nulla dui purus, eleifend vel, consequat non, dictum porta, nulla. Duis ante mi, laoreet ut, commodo 429 | eleifend, cursus nec, lorem. Aenean eu est. Etiam imperdiet turpis. Praesent nec augue. Curabitur 430 | ligula quam, rutrum id, tempor sed, consequat ac, dui. Vestibulum accumsan eros nec magna. 431 | Vestibulum vitae dui. Vestibulum nec ligula et lorem consequat ullamcorper. Class aptent taciti 432 | sociosqu ad litora torquent per conubia nostra, per inceptos hymenaeos. Phasellus eget nisl ut elit 433 | porta ullamcorper. Maecenas tincidunt velit quis orci. Sed in dui. Nullam ut mauris eu mi mollis 434 | luctus. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos hymenaeos. 435 | Sed cursus cursus velit. Sed a massa. Duis dignissim euismod quam. Nullam euismod metus ut orci. 436 | Vestibulum erat libero, scelerisque et, porttitor et, varius a, leo.

437 |
438 | @endif 439 | 440 | @if($basics->table) 441 | 442 |

table

443 |
444 | 445 | 446 | 447 | 448 | 449 | 450 | 451 | 452 | 453 | 454 | 455 | 456 | 457 | 458 | 459 | 460 | 461 | 462 | 463 | 464 | 465 | 466 | 467 | 468 | 469 | 470 | 471 | 472 | 473 | 474 | 477 | 478 | 479 | 480 | 481 | 482 | 483 | 484 | 485 | 486 | 487 | 488 | 489 | 490 | 491 | 492 | 493 | 494 | 495 | 496 | 497 | 500 | 501 | 502 | 503 | 504 | 505 | 506 | 507 | 508 | 509 |
NameTitle of Employee within CompanyHire DateNumberDescription
Bob BarkerWeb Developer05/19/201400234Nulla dui purus, eleifend vel, consequat non, dictum porta, nulla.
Pat SajakConcierge02/24/2011003455Dui purus, eleifend vel, consequat non, dictum porta, nulla.
Steve HarveyConsultant10/19/201343223Eleifend vel, consequat non, dictum porta, nulla. Eleifend vel, consequat non, dictum porta, 475 | nulla. Eleifend vel, consequat non, dictum porta, nulla. 476 |
Alex TrebekMechanic01/09/201600345234225Dui purus, eleifend vel, consequat non, dictum porta, nulla.
Chuck WooleryMakeup01/19/19784322343223Eleifend vel.
Bob EubanksSales12/09/1999003455Dui purus, eleifend vel, consequat non, dictum porta, nulla. Dui purus, eleifend vel, 498 | consequat non, dictum porta, nulla. 499 |
Regis PhilbinIntern01/19/201343223Eleifend vel, consequat non, dictum porta, nulla.
510 | 511 |
512 |

Narrow Table:

513 | 514 | 515 | 516 | 517 | 518 | 519 | 520 | 521 | 522 | 523 | 524 | 525 | 526 | 527 | 528 | 529 | 530 | 531 | 532 | 533 | 534 | 535 | 536 | 537 | 538 | 539 | 540 | 541 | 542 | 543 | 544 | 545 | 546 | 547 | 548 | 549 | 550 |
NameTitle of Employee within Company
Bob BarkerWeb Developer
Pat SajakConcierge
Steve HarveyConsultant
Alex TrebekMechanic
Chuck WooleryMakeup
Bob EubanksSales
Regis PhilbinIntern
551 | 552 |
553 |

Long Table:

554 | 555 | 556 | 557 | 558 | 559 | 560 | 561 | 562 | 563 | 564 | 565 | 566 | 567 | 568 | 569 | 570 | 571 | 572 | 573 | 574 | 575 | 576 | 577 | 578 | 579 | 580 | 581 | 582 | 583 | 584 | 585 | 586 | 587 | 588 | 589 | 590 | 591 | 592 | 593 | 594 | 595 | 596 | 597 | 598 | 599 | 600 | 601 | 602 | 603 | 604 | 605 | 608 | 609 | 610 | 611 | 612 | 613 | 614 | 615 | 616 | 617 | 618 | 619 | 620 | 621 | 622 | 623 | 624 | 625 | 626 |
NameTitle of Employee within CompanyHire DateBirthdayFavorite ColorLucky NumberNumberDescriptionRandom Column HeadingRandom Column HeadingRandom Column Heading
Bob BarkerWeb Developer05/19/201405/19/2014red700234Nulla dui purus, eleifend vel, consequat non, dictum porta, nulla.Random ValueRandom ValueRandom Value
Pat SajakConcierge02/24/201105/19/2014yellow7003455Dui purus, eleifend vel, consequat non, dictum porta, nulla.Random ValueRandom ValueRandom Value
Steve HarveyConsultant10/19/201305/19/2014green743223Eleifend vel, consequat non, dictum porta, nulla. Eleifend vel, consequat non, dictum porta, 606 | nulla. Eleifend vel, consequat non, dictum porta, nulla. 607 | Random ValueRandom ValueRandom Value
Alex TrebekMechanic01/09/201605/19/2014purple700345234225Dui purus, eleifend vel, consequat non, dictum porta, nulla.Random ValueRandom ValueRandom Value
627 |
628 | @endif 629 | 630 | @if($basics->breadcrumbs) 631 | 632 |

breadcrumbs

633 |
634 | 651 |
652 | @endif 653 | 654 | @if($basics->forms) 655 | 656 |

forms

657 |
658 |
659 |

660 | 661 | 662 |

663 |

664 | 665 | 666 |

667 |

668 | 669 | 670 |

671 |

672 | 673 | 674 |

675 |

676 | 677 | 678 |

679 |

680 | 681 | 682 |

683 |

684 | 685 | 686 |

687 |

688 | 689 | 690 |

691 |

692 | 693 | 694 |

695 |

696 | 697 | 698 |

699 |

700 | 701 | 702 |

703 |

704 | 705 | 706 |

707 |

708 | 709 | 710 |

711 |

712 | 713 | 714 |

715 |

716 | 717 | 718 |

719 |

720 | 721 | 722 |

723 |

724 | 725 | 726 |

727 |

728 | 729 | 730 |

731 |

732 | 733 | 740 |

741 |

742 | 743 | 750 |

751 |

752 | 753 | 760 |

761 |

762 | 763 | 773 |

774 |

775 | 776 | 786 |

787 |

788 | 789 | 803 |

804 |

805 | 806 | 807 |

808 |
809 | I am legend 810 |
811 | 812 | 813 |
814 |
815 | 816 | 817 |
818 |
819 | 820 | 821 |
822 |
823 |
824 | I am also legend 825 | 826 | 827 | 828 | 829 |
830 | 831 | 832 |
833 |
834 | @endif 835 | 836 | @if($basics->buttons) 837 | 838 |

buttons

839 |
840 | Link Button 841 | Link Button Active 842 | 843 | 844 | 845 | 846 | 847 | 848 | 849 | 850 | 851 | <a href="javascript:void(0);" class="button">Link Button</a>
852 | <a href="javascript:void(0);" class="button active">Link Button Active</a>
853 | <input type="button" value="Button Input" class="button" />
854 | <input type="reset" value="Form Reset" class="button" />
855 | <button type="button" name="button">Button</button>
856 | <button type="submit" name="submit2">Submit</button>
857 | <button type="reset" name="reset2">Reset</button>
858 | <button disabled>Cancel</button>
859 |
860 |
861 | @endif 862 | @endif 863 | 864 | {{--========================================================================================================--}} 865 | {{--========================================================================================================--}} 866 | {{--========================================================================================================--}} 867 | 868 | @if($patterns) 869 | @foreach($patterns as $pattern) 870 | 871 |

{{$pattern['title']}}

872 |

{!! $pattern['description'] !!}

873 | 874 | {!! $pattern['pattern'] !!} 875 | 876 |
877 |
{!! e($pattern['pattern']) !!}
878 |
879 | @endforeach 880 | @endif 881 |
882 |
883 | 884 | 885 | 886 | -------------------------------------------------------------------------------- /resources/views/index.blade.php: -------------------------------------------------------------------------------- 1 | @extends('styleguide::layout') 2 | 3 | @section('content') 4 |
5 |
6 |

Styleguide Components

7 |

This page displays all the default components found in the styleguide. You will need to place this within your own app to apply your css styles.

8 |

9 | To place within your own blade template files use the component <x-styleguide-base />. 10 |

11 |
12 | 13 | 14 |
15 | @endsection 16 | -------------------------------------------------------------------------------- /resources/views/layout.blade.php: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | @yield('pageTitle', 'Styleguide Preview') 8 | 9 | 10 | @include('styleguide::navigation') 11 |
12 | @yield('content') 13 |
14 | 15 | {{--Footer scripts & styles.--}} 16 | @section('footer') 17 | 18 | 19 | 32 | @show 33 | 34 | -------------------------------------------------------------------------------- /resources/views/navigation.blade.php: -------------------------------------------------------------------------------- 1 | 29 | -------------------------------------------------------------------------------- /resources/views/patterns/create.blade.php: -------------------------------------------------------------------------------- 1 | @extends('styleguide::layout') 2 | 3 | @section('content') 4 | 9 |

Add Custom Pattern

10 |
11 |
12 | @if ($errors->any()) 13 |
14 |
    15 | @foreach ($errors->all() as $error) 16 |
  • {{ $error }}
  • 17 | @endforeach 18 |
19 |

20 | @endif 21 |
22 |
23 | @csrf 24 | 25 | 26 |
27 |
28 | 29 | 30 |
31 |
32 | 33 | 34 |
35 | 36 |
37 |
38 |
39 | @endsection 40 | 41 | @section('footer') 42 | @parent 43 | @include('styleguide::codemirror') 44 | @stop 45 | -------------------------------------------------------------------------------- /resources/views/patterns/edit.blade.php: -------------------------------------------------------------------------------- 1 | @extends('styleguide::layout') 2 | 3 | @section('content') 4 | 9 |

Edit Custom Pattern

10 |
11 |
12 | @if ($errors->any()) 13 |
14 |
    15 | @foreach ($errors->all() as $error) 16 |
  • {{ $error }}
  • 17 | @endforeach 18 |
19 |

20 | @endif 21 |
22 |
23 | @csrf 24 | @method('PATCH') 25 | 26 | 27 |
28 |
29 | 30 | 31 |
32 |
33 | 34 | 35 |
36 | 37 |
38 |
39 |
40 | @endsection 41 | 42 | @section('footer') 43 | @parent 44 | @include('styleguide::codemirror') 45 | @stop 46 | -------------------------------------------------------------------------------- /resources/views/patterns/list.blade.php: -------------------------------------------------------------------------------- 1 | @extends('styleguide::layout') 2 | 3 | @section('content') 4 | 9 |

Patterns

10 |
11 | @if(session()->get('success')) 12 |
13 | {{ session()->get('success') }} 14 |

15 | @endif 16 | 17 |
18 | Add pattern 19 |
20 | 21 | @if(!$patterns->isEmpty()) 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 | @foreach($patterns as $pattern) 33 | 34 | 35 | 36 | 37 | 38 | 45 | 46 | @endforeach 47 | 48 |
IDTitleDescriptionAction
{{$pattern->id}}{{$pattern->title}}{!! $pattern->description !!}Edit 39 |
40 | @csrf 41 | @method('DELETE') 42 | 43 |
44 |
49 | @endif 50 |
51 | @endsection 52 | -------------------------------------------------------------------------------- /routes/routes.php: -------------------------------------------------------------------------------- 1 | w/in your own templates. 9 | | 10 | */ 11 | Route::get( 12 | 'admin/styleguide', 13 | '\Xpersonas\Styleguide\Http\Controllers\StyleguideController@index' 14 | )->name('simple-styleguide'); 15 | 16 | /* 17 | |-------------------------------------------------------------------------- 18 | | Styleguide Admin Route. 19 | |-------------------------------------------------------------------------- 20 | | 21 | */ 22 | Route::prefix('admin/styleguide')->group(function () { 23 | Route::resource( 24 | 'patterns', 25 | 'Xpersonas\Styleguide\Http\Controllers\StyleguidePatternController', 26 | ['names' => 'pattern'] 27 | )->middleware(['web']); 28 | 29 | Route::resource( 30 | 'colors', 31 | 'Xpersonas\Styleguide\Http\Controllers\StyleguideColorController', 32 | ['names' => 'color'] 33 | )->middleware(['web']); 34 | 35 | Route::resource( 36 | 'basics', 37 | 'Xpersonas\Styleguide\Http\Controllers\StyleguideBasicsController', 38 | ['names' => 'basics'] 39 | )->middleware(['web']); 40 | }); 41 | -------------------------------------------------------------------------------- /webpack.mix.js: -------------------------------------------------------------------------------- 1 | const mix = require('laravel-mix'); 2 | 3 | /* 4 | |-------------------------------------------------------------------------- 5 | | Mix Asset Management 6 | |-------------------------------------------------------------------------- 7 | | 8 | | Mix provides a clean, fluent API for defining some Webpack build steps 9 | | for your Laravel application. By default, we are compiling the Sass 10 | | file for the application as well as bundling up all the JS files. 11 | | 12 | */ 13 | 14 | mix.sourceMaps() 15 | .js('resources/js/styleguide.js', 'public/js') 16 | .babel(['public/js/styleguide.js'], 'public/js/styleguide.js') 17 | .sass('resources/sass/styleguide.scss', 'public/css') 18 | .options({ 19 | postCss: [ 20 | require('autoprefixer')({ 21 | grid: true 22 | }) 23 | ] 24 | }); 25 | --------------------------------------------------------------------------------