From a9feb6fa7c2b8edefbc9fe96a8a84e2b844b4aee Mon Sep 17 00:00:00 2001 From: hastom Date: Mon, 13 May 2019 21:42:26 +0300 Subject: [PATCH 1/6] fix(MdRadio): internal radio not being checked (#2063) --- src/components/MdRadio/MdRadio.vue | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/components/MdRadio/MdRadio.vue b/src/components/MdRadio/MdRadio.vue index b830e28cd..a7623c5fa 100644 --- a/src/components/MdRadio/MdRadio.vue +++ b/src/components/MdRadio/MdRadio.vue @@ -2,7 +2,7 @@
- +
From c27469373c82911a0524b02cfa6022de495658f7 Mon Sep 17 00:00:00 2001 From: hastom Date: Mon, 13 May 2019 21:43:27 +0300 Subject: [PATCH 2/6] fix(MdMenu): unexpected close on item click (#2062) --- src/components/MdMenu/MdMenuContent.vue | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/components/MdMenu/MdMenuContent.vue b/src/components/MdMenu/MdMenuContent.vue index 347a94d07..6da1a64ae 100644 --- a/src/components/MdMenu/MdMenuContent.vue +++ b/src/components/MdMenu/MdMenuContent.vue @@ -208,7 +208,7 @@ this.MdMenu.bodyClickObserver = new MdObserveEvent(document.body, 'click', $event => { $event.stopPropagation() - if (!this.isMenu($event) && (this.MdMenu.closeOnClick || this.isBackdropExpectMenu($event))) { + if (!this.isMenuContentEl($event) && (this.MdMenu.closeOnClick || this.isBackdropExpectMenu($event))) { this.MdMenu.active = false this.MdMenu.bodyClickObserver.destroy() this.MdMenu.windowResizeObserver.destroy() From ff6d041b4f1716e1d7d23451aedd0487b893b97d Mon Sep 17 00:00:00 2001 From: Marcos Moura Date: Tue, 25 Jun 2019 01:48:30 +0200 Subject: [PATCH 3/6] docs: add funding --- FUNDING.yml | 2 ++ 1 file changed, 2 insertions(+) create mode 100644 FUNDING.yml diff --git a/FUNDING.yml b/FUNDING.yml new file mode 100644 index 000000000..a6c03fff9 --- /dev/null +++ b/FUNDING.yml @@ -0,0 +1,2 @@ +patreon: marcosmoura +custom: http://bit.ly/VueMaterialPaypal From f6f42ffbab3138e15dfcd5eaf93354cf2398a400 Mon Sep 17 00:00:00 2001 From: Adrien Boutigny Date: Thu, 14 Nov 2019 11:48:09 +0100 Subject: [PATCH 4/6] test: add a "testURL" field to jest config (#2082) fixes the " SecurityError: localStorage is not available for opaque origins" error message that everyone seems to get on their PRs. Using the solution provided here https://github.com/facebook/jest/issues/3630 --- package.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/package.json b/package.json index db8e5d65c..e1bffb178 100644 --- a/package.json +++ b/package.json @@ -156,7 +156,8 @@ "lcov", "json", "html" - ] + ], + "testURL": "http://localhost:8080" }, "browserslist": [ "> 1%" From df77927fdf58edc5d2313391fcef4c7465d9157f Mon Sep 17 00:00:00 2001 From: rarestoma Date: Thu, 14 Nov 2019 13:04:35 +0200 Subject: [PATCH 5/6] Docs/restyle (#2139) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Changed 'roboto mono' to 'roboto' * Changed code fund position to bottom right * updates Added ‘supported by Creative Tim’ in About page Added open collective * added links to header * Removed disclaimer, added sponsors, changed footer * Add premium-themes page and link to it from the footer * Added products to premium themes page * Finished premium page * Finished installation/usage/premium-themes section * Installed vue-github-buttons * Added GitHub star button * Added license, download and chat buttons * Changed order in gh star button * Changed page transition * Added vue-toc * Style modified for toc * Added ids on getting started for vue-toc * Added ids on themes-congifuration for vue-toc * Added ids on layouts for vue-toc * Added ids on typography * Added ids on components->app for vue-toc * Added ids on buttomBar for vue-toc * Added ids on Button for vue-toc * Added ids on Card for vue-toc * Added ids on datepicker for vue-toc * Added ids on Dialog for vue-toc * Added ids on Drawer for vue-toc * Added ids on autocomplete for vue-toc * Added ids on Chips for vue-toc * Added ids on Input for vue-toc * Added ids on Icon for vue-toc * Added ids on List for vue-toc * Added ids on Menu for vue-toc * Added ids on speedDial for vue-toc * Added ids on steppers for vue-toc * Added ids on table for vue-toc * Added ids on Tabs for vue-toc * Added ids on toolbar for vue-toc * Added ids on Tooltip for vue-toc * Updated license * Added key to vue-toc * Small change * Changed codeinwp logo * updates * Css changes for logo and gh-button * Added more space between buttons * Removed arrow down & nabber buttons hidden on mobile * style changes, added premium themes in navbar, centered premium themes * Cards change * toc style * Changed style for code-fund * restyle codefund * Restyled home premium section * Commented contribuitors section * Changed Patreon text to Open Collective * Changed home premium background color * Removed open collective * Added link to premium-themes from themes image * Added target blank * Restyled vue-toc * added refs * Responsive changes * Changed margin on title * Added custom development link * Added links from sponsors * lint fix * add margin left --- docs/app/App.vue | 3 +- docs/app/components/AdManager.vue | 14 +- docs/app/components/PageContainer.vue | 25 +++ docs/app/i18n/en-US/pages.js | 3 +- docs/app/index.js | 7 + docs/app/pages/About.vue | 12 +- docs/app/pages/Components/App/App.vue | 12 +- .../Components/Autocomplete/Autocomplete.vue | 12 +- docs/app/pages/Components/Avatar/Avatar.vue | 6 +- .../pages/Components/BottomBar/BottomBar.vue | 8 +- docs/app/pages/Components/Button/Button.vue | 10 +- docs/app/pages/Components/Card/Card.vue | 12 +- docs/app/pages/Components/Chips/Chips.vue | 14 +- .../Components/Datepicker/Datepicker.vue | 10 +- docs/app/pages/Components/Dialog/Dialog.vue | 8 +- docs/app/pages/Components/Drawer/Drawer.vue | 6 +- docs/app/pages/Components/Icon/Icon.vue | 6 +- docs/app/pages/Components/Input/Input.vue | 12 +- docs/app/pages/Components/List/List.vue | 4 +- docs/app/pages/Components/Menu/Menu.vue | 12 +- .../pages/Components/SpeedDial/SpeedDial.vue | 8 +- .../pages/Components/Steppers/Steppers.vue | 10 +- docs/app/pages/Components/Table/Table.vue | 6 +- docs/app/pages/Components/Tabs/Tabs.vue | 10 +- docs/app/pages/Components/Toolbar/Toolbar.vue | 6 +- docs/app/pages/Components/Tooltip/Tooltip.vue | 6 +- docs/app/pages/GettingStarted.vue | 7 +- docs/app/pages/Home/Home.vue | 13 +- docs/app/pages/Home/HomeHeader.vue | 49 ++++- docs/app/pages/Home/HomePremium.vue | 182 ++++++++++++++---- docs/app/pages/Home/HomeSponsors.vue | 43 ++++- docs/app/pages/License.vue | 3 +- .../app/pages/PremiumThemes/PremiumThemes.vue | 142 ++++++++++++++ docs/app/pages/Themes/Configuration.vue | 10 +- docs/app/pages/UiElements/Layout/Layout.vue | 4 +- .../UiElements/Typography/Typography.vue | 4 +- docs/app/routes.js | 5 + docs/app/template/MainFooter.vue | 49 ++++- docs/app/template/MainHeader.vue | 22 +++ docs/app/template/MainNav.vue | 36 ++++ docs/app/template/MainNavContent.vue | 46 ++++- docs/assets/premium/premium-themes.png | Bin 0 -> 1949098 bytes docs/assets/sponsors/codeinwp-logo.png | Bin 0 -> 11410 bytes docs/assets/sponsors/codeinwp-logo.svg | 1 + docs/assets/sponsors/creative-tim.png | Bin 0 -> 51328 bytes docs/assets/sponsors/opencollective.png | Bin 0 -> 4452 bytes docs/assets/sponsors/opencollective.svg | 1 + docs/assets/sponsors/patreon.png | Bin 1551 -> 0 bytes package.json | 7 +- 49 files changed, 679 insertions(+), 187 deletions(-) create mode 100644 docs/app/pages/PremiumThemes/PremiumThemes.vue create mode 100644 docs/assets/premium/premium-themes.png create mode 100644 docs/assets/sponsors/codeinwp-logo.png create mode 100644 docs/assets/sponsors/codeinwp-logo.svg create mode 100644 docs/assets/sponsors/creative-tim.png create mode 100644 docs/assets/sponsors/opencollective.png create mode 100644 docs/assets/sponsors/opencollective.svg delete mode 100644 docs/assets/sponsors/patreon.png diff --git a/docs/app/App.vue b/docs/app/App.vue index 62d2bc17b..b1ddac58e 100644 --- a/docs/app/App.vue +++ b/docs/app/App.vue @@ -3,7 +3,7 @@
- +
Loading page... @@ -93,7 +93,6 @@ padding-top: 64px; display: flex; flex-direction: column; - font-family: "Roboto Mono", monospace; transition: $md-transition-default; transition-property: padding-top; diff --git a/docs/app/components/AdManager.vue b/docs/app/components/AdManager.vue index 0bb138da9..c627b0c27 100644 --- a/docs/app/components/AdManager.vue +++ b/docs/app/components/AdManager.vue @@ -36,17 +36,23 @@ $ad-responsive-small: 768px; .ad-manager { - width: calc(100% + 32px); - margin: 0 -16px -16px; + right: 0; + bottom: 0; + border-top-left-radius: 4px; + z-index: 2000; + margin-bottom: 150px; @media (max-width: $ad-responsive-small) { display: flex; } } + .home-page .ad-manager{ + background: #303030; + } + .code-fund { max-width: 175px; - margin: 0 16px 24px 16px; padding: 8px; display: flex; flex-direction: column; @@ -74,7 +80,7 @@ @media (max-width: $ad-responsive-big) { max-width: 530px; min-height: 100px; - margin: 60px auto 8px; + margin: 0px auto 8px; float: none; background: none !important; } diff --git a/docs/app/components/PageContainer.vue b/docs/app/components/PageContainer.vue index bef242271..7a523904f 100644 --- a/docs/app/components/PageContainer.vue +++ b/docs/app/components/PageContainer.vue @@ -48,6 +48,15 @@ margin: 0 auto; padding: 16px; transition: .4s $md-transition-default-timing; + transition-property: width; + } + + @media(min-width:981px){ + .page-container.centered{ + + margin-right: 280px; + } + } .page-container-leave-active { @@ -98,4 +107,20 @@ } } } + + .ad-manager{ + margin-bottom: 0 !important; + position: fixed; + } + + @media(max-width: 960px){ + .ad-manager{ + position: relative; + >>>.code-fund{ + float: none; + margin: 0; + + } + } + } diff --git a/docs/app/i18n/en-US/pages.js b/docs/app/i18n/en-US/pages.js index 20236f671..6378726f7 100644 --- a/docs/app/i18n/en-US/pages.js +++ b/docs/app/i18n/en-US/pages.js @@ -10,11 +10,12 @@ export default { featuredContent: 'Complete with dynamic themes, on-demand components and all with an easy-to-use API.', ecosystem: 'Ecosystem', premium: 'Premium Themes', + custom: 'Custom Development', viewProject: 'View project', sponsors: 'Sponsors', backers: 'Backers', sponsorsDescription: 'Vue Material does not run under the umbrella of any company or anything like that. It is an independent project created by {0} in his spare time, which has become one of the most used UI Libraries for Vue.js. The development is active and we are working hard to release great things for you.', - beAPatron: 'If you think that this project helped you or your company in any way, you can consider becoming a backer/sponsor on Patreon' + beACollective: 'If you think that this project helped you or your company in any way, you can consider becoming a backer/sponsor on Open Collective' }, about: { title: 'About' diff --git a/docs/app/index.js b/docs/app/index.js index b9a309581..65303cbec 100644 --- a/docs/app/index.js +++ b/docs/app/index.js @@ -4,6 +4,12 @@ import Vue from 'vue' import ga from 'vue-ga' import { sync } from 'vuex-router-sync' import VueMaterial from 'vue-material' +import VueGitHubButtons from 'vue-github-buttons' +import VueToc from 'vue-toc' + +Vue.component('vue-toc', VueToc) + +import 'vue-github-buttons/dist/vue-github-buttons.css'; /* App */ import App from './App' @@ -14,6 +20,7 @@ import './components' Vue.config.productionTip = false Vue.use(VueMaterial) +Vue.use(VueGitHubButtons) ga(router, 'UA-85823257-1') sync(store, router) diff --git a/docs/app/pages/About.vue b/docs/app/pages/About.vue index a7dc3cd7f..a6c350189 100644 --- a/docs/app/pages/About.vue +++ b/docs/app/pages/About.vue @@ -32,14 +32,13 @@

This project started as a side project and became the library as it is today, one of the most used UI Libraries for Vue.js!

-
+

Want to contribute with the Project?

@@ -69,6 +68,7 @@
@@ -122,7 +122,7 @@ vertical-align: middle; } - .about-patreon { + .about-collective { max-width: 180px; display: inline-block; } diff --git a/docs/app/pages/Components/App/App.vue b/docs/app/pages/Components/App/App.vue index 0f774a551..8ffe70556 100644 --- a/docs/app/pages/Components/App/App.vue +++ b/docs/app/pages/Components/App/App.vue @@ -25,7 +25,7 @@
-

{{ $t('pages.app.regular.title') }}

+

{{ $t('pages.app.regular.title') }}

{{ $t('pages.app.regular.desc1') }}

@@ -35,35 +35,35 @@
-

{{ $t('pages.app.fixed.title') }}

+

{{ $t('pages.app.fixed.title') }}

{{ $t('pages.app.fixed.desc') }}

-

{{ $t('pages.app.reveal.title') }}

+

{{ $t('pages.app.reveal.title') }}

{{ $t('pages.app.reveal.desc') }}

-

{{ $t('pages.app.flexible.title') }}

+

{{ $t('pages.app.flexible.title') }}

{{ $t('pages.app.flexible.desc') }}

-

{{ $t('pages.app.lastRow.title') }}

+

{{ $t('pages.app.lastRow.title') }}

{{ $t('pages.app.lastRow.desc') }}

-

{{ $t('pages.app.overlap.title') }}

+

{{ $t('pages.app.overlap.title') }}

{{ $t('pages.app.overlap.desc') }}

diff --git a/docs/app/pages/Components/Autocomplete/Autocomplete.vue b/docs/app/pages/Components/Autocomplete/Autocomplete.vue index 957d32a1d..8cc62ff96 100644 --- a/docs/app/pages/Components/Autocomplete/Autocomplete.vue +++ b/docs/app/pages/Components/Autocomplete/Autocomplete.vue @@ -14,28 +14,28 @@
-

Static Data

+

Static Data

If you have a small amount of data or if it's static, you can pass the options to md-autocomplete in a simple and intuitive way:

-

Trigger

+

Trigger

By default the suggestions will appear along with a focus trigger. If you want something less intrusive, you can disable this behaviour by canceling the focus event. If this, the suggestions will appear right after a keystroke:

-

Box Layout

+

Box Layout

Autocomplete have types two layouts: Default with floating labels and a boxed layout with inline labels. The box layout will apply a boxed layout with a small elevation, that also works really great as search bar inside a toolbar. Gorgeous:

-

Custom Template

+

Custom Template

This section will assume that you have knowledge of Vue Scoped Slots. This will allow you to customize the option list.

Autocomplete also accepts a custom template, flexible to accept any HTML element and with an 'empty state' built in. You can also highlight the search term inside the matches, to give a feedback on why that item has been in the results. Awesome:

@@ -44,7 +44,7 @@
-

Search Algorithms

+

Search Algorithms

Vue Material autocomplete comes with 2 ways of search: Fuzzy search and search by whole term. The fuzzy search tries to match the results by approximation, finding patterns inside the available options. This will help with accidental type errors and improve the results. If you think that this may be confusing, you can disable this. Example:

@@ -85,7 +85,7 @@
-

Async Options

+

Async Options

Sometimes the options are inside a database in a remote server. Instead of giving a static data, we can provide a Promise that will resolve with the data from a backend servide, for example. This is great to save Bandwidth on the initial load and to improve the performance. Look at this example:

diff --git a/docs/app/pages/Components/Avatar/Avatar.vue b/docs/app/pages/Components/Avatar/Avatar.vue index 0a3bbecf4..eb2510a73 100644 --- a/docs/app/pages/Components/Avatar/Avatar.vue +++ b/docs/app/pages/Components/Avatar/Avatar.vue @@ -9,7 +9,7 @@
-

Avatar

+

Avatar

Avatars can show a single image by default but can also display an icon (using the md-icon component):

@@ -21,14 +21,14 @@
-

Initial letter as a placeholder

+

Initial letter as a placeholder

Let's assume that you want to show a list of contacts, but some of them do not have a picture in your database. You can use the initial letter of the contact name as a placeholder. It can even show 2 letters (for compound names) without problems:

-

Multiple sizes

+

Multiple sizes

You can specify three different sizes, if you want: Regular, Small or Large. By default the avatar have a regular size.

diff --git a/docs/app/pages/Components/BottomBar/BottomBar.vue b/docs/app/pages/Components/BottomBar/BottomBar.vue index fa803bc2c..dfb2a2301 100644 --- a/docs/app/pages/Components/BottomBar/BottomBar.vue +++ b/docs/app/pages/Components/BottomBar/BottomBar.vue @@ -10,7 +10,7 @@
-

Seamless integration with Vue Router

+

Seamless integration with Vue Router

The bottom bar is compatible with all Vue Router options. Just pass the values as parameters on md-bottom-bar-item component:

@@ -18,21 +18,21 @@
-

Shift effect

+

Shift effect

You can also use the awesome shift effect on your bars. It is great to keep the focus of the active item and you can show up to 6 items at once:

-

Dynamic Themes

+

Dynamic Themes

Sometimes each part of your application have it's own color theme, like in a social media app. You can change the theme dynamically to morph states creating an immersive experience:

-

Custom Template

+

Custom Template

Maybe you want to show more informations inside a bottom bar item. With a simple and flexible default slot, you can make anything you want. Look at this unread notification example:

If you pass anything inside the <md-bottom-bar-item>, the component will ignore the md-label and md-icon. Only use the content slot if you want to create a custom template. diff --git a/docs/app/pages/Components/Button/Button.vue b/docs/app/pages/Components/Button/Button.vue index 202d1a17e..bfca3c2ed 100644 --- a/docs/app/pages/Components/Button/Button.vue +++ b/docs/app/pages/Components/Button/Button.vue @@ -11,7 +11,7 @@
-

Flat and Raised

+

Flat and Raised

The flat button is the default one. No classes or properties needs to be attached to it to make it flat. The raised button can be achieved with the md-raised class.

@@ -26,7 +26,7 @@
-

Icons

+

Icons

To display icons inside buttons you only need to add a class and you're good to go. And you can also combine it with the raised class.

@@ -39,7 +39,7 @@
-

Floating Action Buttons

+

Floating Action Buttons

A Floating Action Button represents the primary action in an application and is used for a promoted action. FAB buttons can be regular sized or mini, with an accent color by default. This type of buttons can only have icons, so it should be used along with <md-icon>.

Use only one FAB per page and only if the purpose of the button is to fire the main action of the screen. Otherwise use md-icon-button. @@ -53,14 +53,14 @@
-

Link Vs Buttons

+

Link Vs Buttons

All buttons by default will output a button tag. If you want to change it to a a tag, just pass it a href:

-

Vue Router

+

Vue Router

md-button also supports Vue Router by default. All options of router-link could be simply used here.

diff --git a/docs/app/pages/Components/Card/Card.vue b/docs/app/pages/Components/Card/Card.vue index 6c45f95b6..9fd88f0be 100644 --- a/docs/app/pages/Components/Card/Card.vue +++ b/docs/app/pages/Components/Card/Card.vue @@ -13,7 +13,7 @@
-

Regular Cards

+

Regular Cards

The simplest card structure has a header, content area and action buttons, defined by md-card-header, md-card-content and md-card-actions, respectively. The header may contain a title and a subtitle div or span with classes .md-title and .md-subhead. In the content area, you may use any kind of text elements and for the actions, use at most two md-buttons.

@@ -21,7 +21,7 @@ -

Cards with Images

+

Cards with Images

To add visual appeal to your cards, you can add images inside the md-header tag with a md-card-media wraping an img tag. It's possible to increase the image size to medium or big with the properties md-medium and md-big.

@@ -43,20 +43,20 @@ If there isn't sufficient contrast between background image and title, the latter won't be perfectly legible. To overcome that, apply a solid or gradient background to the text by using the md-card-media-cover's properties md-solid or md-text-scrim, respectively. - -

Themes

+ +

Themes

Your cards will stand out if you change their base color... And you can do it by applying themes! Just add a .primary or accent class on them. This will use the current theme. You can specify a custom one with the md-theme property.

-

Expansion Control

+

Expansion Control

To avoid too much information inside a card, or keep its height from exceeding the maximum height, hide supplementary information inside a expansible area.

It can be done with the md-card-expand component, that has a md-card-action with a md-card-expand-trigger that toggles a md-card-expand-content.

-

Different Layouts

+

Different Layouts

That's pretty much it. You can now combine these and other components in many distinct ways. Here are some examples: diff --git a/docs/app/pages/Components/Chips/Chips.vue b/docs/app/pages/Components/Chips/Chips.vue index 0656f7101..f9096457c 100644 --- a/docs/app/pages/Components/Chips/Chips.vue +++ b/docs/app/pages/Components/Chips/Chips.vue @@ -13,7 +13,7 @@
-

Standalone Chip

+

Standalone Chip

A chip can be used as standalone, without any connection with another chip. It can be used like a badge or a category of an entity in your application. You can specify if your chip can be deletable and clickable:

@@ -27,42 +27,42 @@
-

Editable model

+

Editable model

Sometimes we need to edit the set of items on screen, for example, when editing tags, the user may need to remove/add tags. In this case you can use the editable chips, that is the default behaviour:

-

Readonly

+

Readonly

Let's think in an entity that have tags. Sometimes you might need to show all of them in a single row, but not allow the user to edit them. You can achieve that using the md-chips component, with a static option:

-

Custom Template

+

Custom Template

Sometimes we need to show more information about a chip, so we want to have a custom HTML structure for the chip itself. To create that scenario we can use the template scope. In this case all you have to do is to create a slot with your custom template and you're good to go. Take a look at this example:

-

Duplicated Chip

+

Duplicated Chip

Chips would reject insertion if a chip is duplicated. You can customize feedback style of the duplicated chip:

-

Formatter

+

Formatter

Sometimes you may need to format a chip value before adding it, and for this case you can use a custom formatter function. This function will receive the chip value and must return the formatted value.

-

Hue Colors

+

Hue Colors

You can always use the hue modifiers in single chips:

diff --git a/docs/app/pages/Components/Datepicker/Datepicker.vue b/docs/app/pages/Components/Datepicker/Datepicker.vue index b24886029..de5e77f76 100644 --- a/docs/app/pages/Components/Datepicker/Datepicker.vue +++ b/docs/app/pages/Components/Datepicker/Datepicker.vue @@ -12,7 +12,7 @@
-

Datepicker

+

Datepicker

@@ -20,25 +20,25 @@
-

Model Types

+

Model Types

Vue Material datepicker supports multiple types of v-model, whiches default is Date. If you want to communicate with other services without timezone problems, you could use String to avoid them:

-

Cancel open on focus

+

Cancel open on focus

By default Datepicker component open on focus to it's input. This will make the input useless and the user will not be able to type the date manually. You can disable this behavior:

-

Immediately selection

+

Immediately selection

The Datepicker dialog can be made to close instantly after a date is selected. The date will be selected immediately without any additional confirmation or user action:

-

Disabled dates

+

Disabled dates

Sometimes you may need to disable certain dates from being selected. Let's suppose that you want to let the user select only week days:

diff --git a/docs/app/pages/Components/Dialog/Dialog.vue b/docs/app/pages/Components/Dialog/Dialog.vue index ab954b32d..d18f5316e 100644 --- a/docs/app/pages/Components/Dialog/Dialog.vue +++ b/docs/app/pages/Components/Dialog/Dialog.vue @@ -13,7 +13,7 @@
-

Dialog

+

Dialog

The Dialog component can have any HTML markup inside. This allows you to create rich dialog content, like the details of a table row, for example:

@@ -27,7 +27,7 @@
-

Alerts

+

Alerts

@@ -39,7 +39,7 @@
-

Confirms

+

Confirms

@@ -52,7 +52,7 @@
-

Prompts

+

Prompts

diff --git a/docs/app/pages/Components/Drawer/Drawer.vue b/docs/app/pages/Components/Drawer/Drawer.vue index 08d6f3ce8..00482a721 100644 --- a/docs/app/pages/Components/Drawer/Drawer.vue +++ b/docs/app/pages/Components/Drawer/Drawer.vue @@ -15,14 +15,14 @@
-

Temporary

+

Temporary

Temporary navigation drawers are closed by default and opens temporarily above all other content until a section is selected. This is highly recommended for mobile devices. If you do not pass any options to drawer this will be the default preset:

-

Permanent

+

Permanent

Permanent navigation drawers are always visible and pinned to the left edge, at the same elevation as the content or background. They cannot be closed and are recommended default for desktop.

They come with three sub-types: Full, Clipped and Card:

@@ -40,7 +40,7 @@
-

Persistent

+

Persistent

Persistent navigation drawers can toggle open or closed. The drawer sits on the same surface elevation as the content. It is closed by default and opens by selecting the menu icon, and stays open until closed by the user.

They come with two sub-types: Full and Mini:

diff --git a/docs/app/pages/Components/Icon/Icon.vue b/docs/app/pages/Components/Icon/Icon.vue index 311e6f1d9..a7728f8ae 100644 --- a/docs/app/pages/Components/Icon/Icon.vue +++ b/docs/app/pages/Components/Icon/Icon.vue @@ -9,7 +9,7 @@
-

Material Icon Font

+

Material Icon Font

By default the md-icon will assume that you are using the Material Icons Font. You have to pass the name of the icon with underscore instead of spaces. For example: <md-icon>thumb_up</md-icon>.

@@ -23,14 +23,14 @@
-

Custom Fonts

+

Custom Fonts

Alternatevely you can load any custom fonts to be used with md-icon, like Font Awesome for example. Just use the Font Awesome (or any other) classes.

-

SVG Source

+

SVG Source

When loading an icon font, you will be able to use ALL of it's icons. This may hurt the performance of your application. Instead, you can use only the icons that you really need, loading them using svg.

diff --git a/docs/app/pages/Components/Input/Input.vue b/docs/app/pages/Components/Input/Input.vue index cd41f140f..f3abcd2ba 100644 --- a/docs/app/pages/Components/Input/Input.vue +++ b/docs/app/pages/Components/Input/Input.vue @@ -14,7 +14,7 @@
-

Text Fields

+

Text Fields

Fields mimic the HTML5 attributes to keep the same compatibility with native inputs, but has extra options. This allows Vue Material to accordingly setup the various md-field with its corresponding input options.

You will be able to set the same properties of a regular input element on md-input. This is also valid for textarea and select. Take a look:

@@ -22,35 +22,35 @@
-

Errors and Messages

+

Errors and Messages

Vue Material has validation states to show error messages. You can use it along with other 3rd party Vue validation libraries, like Vuelidate or Vee-Validate:

-

Character count

+

Character count

You can use character counters where you need to limit the user input, like on Twitter's 280 character tweet:

-

Icons

+

Icons

Sometimes we may want to differentiate our inputs based on it content value:

-

Inline Actions

+

Inline Actions

Fields can have a clearable feature to make it easier for users to clear the value. To use passwords better we can show a toggle button to reveal the password. This is really useful for mobile applications:

-

Prefixes & suffixes

+

Prefixes & suffixes

Prefixes and suffixes can be used to clarify units or to add input in advance. Prefixes are left justified in the text field whereas suffixes are right justified. Text fields can have both prefixes and suffixes.

diff --git a/docs/app/pages/Components/List/List.vue b/docs/app/pages/Components/List/List.vue index cf2263972..cf826b37c 100644 --- a/docs/app/pages/Components/List/List.vue +++ b/docs/app/pages/Components/List/List.vue @@ -14,7 +14,7 @@
-

List

+

List

Single line lists are really great for navigational elements, such as drawers. You can pass a icons, text and actions to them. They have also a dense layout, to accommodate more items on the screen:

@@ -31,7 +31,7 @@
-

List Actions

+

List Actions

List items will render different tags based on the interaction types given.

If you pass one of those event, the item will automatically render a button:

diff --git a/docs/app/pages/Components/Menu/Menu.vue b/docs/app/pages/Components/Menu/Menu.vue index cd2d893ea..71aa8e982 100644 --- a/docs/app/pages/Components/Menu/Menu.vue +++ b/docs/app/pages/Components/Menu/Menu.vue @@ -12,7 +12,7 @@
-

Directions

+

The position of the menu content is calculated based on the contraints of the trigger element. Based on this you can set a position using X and Y axis.

You can combine top/bottom with start/end:

@@ -20,14 +20,14 @@
-

Alignments

+

Sometimes the default position is not what we want. Maybe we need to show a menu in another location, and to achieve that you can use trigger alignment or custom offsets:

-

Sizes

+

md-menu has 4 different sizes and an auto mode:

@@ -35,14 +35,14 @@
-

AutoClose

+

md-menu can be auto closed on click or select:

-

Rich Content and Icon Alignment

+

Sometimes you may need to toggle your menu dynamically. You can also show arbitrary content inside a md-menu-content, like this card example:

@@ -202,7 +202,7 @@ value: 'null' } ] - } + } }) } diff --git a/docs/app/pages/Components/SpeedDial/SpeedDial.vue b/docs/app/pages/Components/SpeedDial/SpeedDial.vue index 828a5e81f..fabc64c52 100644 --- a/docs/app/pages/Components/SpeedDial/SpeedDial.vue +++ b/docs/app/pages/Components/SpeedDial/SpeedDial.vue @@ -12,7 +12,7 @@
-

Speed Dial positions

+

Speed Dial positions

You can specify any position that you want for you Speed Dial component. They can be top and bottom, and combined with left, center or right:

@@ -20,13 +20,13 @@
-

Effects

+

Effects

The component can be displayed different animations for each scenario that you might want:

-

Triggers

+

Triggers

You can trigger the speed dial content using hover or click. Using this allows you to have a open/close feature or to hold a main action:

For desktop environments it's better to have a hover effect. On mobile you can toggle the property to use click instead. @@ -38,7 +38,7 @@
-

Icon Morph

+

Icon Morph

Sometimes you want the speed dial to have a cross icon to represent your close action after showing the content. This can be easily achieved with the morph icons.

To create that, create two md-icon components inside the trigger and add a md-morph-initial in the one you would like it to be the initial state (or an open state) and a md-morph-final on the close state:

diff --git a/docs/app/pages/Components/Steppers/Steppers.vue b/docs/app/pages/Components/Steppers/Steppers.vue index 27f8e8021..e024d812d 100644 --- a/docs/app/pages/Components/Steppers/Steppers.vue +++ b/docs/app/pages/Components/Steppers/Steppers.vue @@ -13,7 +13,7 @@
-

Horizontal Steppers

+

Horizontal Steppers

Horizontal steppers are ideal when the contents of one step depend on an earlier step. You should avoid using long step names in horizontal steppers.

This is the default type of steppers. They are not recommended for mobile:

@@ -24,28 +24,28 @@
-

Vertical Steppers

+

Vertical Steppers

Vertical steppers are great deal for mobile devices or to be inserted on small areas of your application, like a dialog or a card.

-

Linear Steppers

+

Linear Steppers

By default steps are optional and this means that you can advance to the last step without pass through the other ones. But sometimes we're guiding an user through a linear flow and all steps matter or are connected together. Linear steppers require users to complete one step in order to move on to the next:

-

Non Editable Steps

+

Non Editable Steps

By default steps are also editable. But you can disable this by manually setting on each step that could be non-editable. This makes sense when users cannot edit a step later or when step editing poses a distraction risk to form completion:

-

Vue Router Integration

+

Vue Router Integration

Vue Material Steppers have a deep integratio with Vue Router. This means that you can have a route per step. This allows you to navigate between steps through the browser history, store the current stepper after a refresh and lots of great scenarios that you can explore! Take a look at the page URL changing when clicking on each steps:

Try to refresh the page to see that Steppers will detect the active step based on the current URL. Just awesome! diff --git a/docs/app/pages/Components/Table/Table.vue b/docs/app/pages/Components/Table/Table.vue index b571cdaf5..4e1914fc5 100644 --- a/docs/app/pages/Components/Table/Table.vue +++ b/docs/app/pages/Components/Table/Table.vue @@ -17,7 +17,7 @@
-

Simple tables

+

Simple tables

To create a basic table, with simple data and without any advanced options, you have a really simple markup to use.

There are some components that mimic the native table elements:

@@ -50,7 +50,7 @@
-

Advanced tables

+

Advanced tables

This section will assume that you have knowledge of Vue Scoped Slots. You'll need them to create advanced tables. @@ -83,7 +83,7 @@
-

Selection

+

Selection

When dealing with large data sets, you may want to have quick actions over our data, like whether to remove or make some bulk change. Tables have inner selection in two ways: Single and Multiple.

The single selection is really great to highlight a particular item. Maybe, by clicking on a table row, will show the details of the item. With single selections you'll have access to the selected item and the table will do the rest. You can use the primary and accent hue colors to give more appealing highlight colors:

diff --git a/docs/app/pages/Components/Tabs/Tabs.vue b/docs/app/pages/Components/Tabs/Tabs.vue index 84b11aff5..776239c63 100644 --- a/docs/app/pages/Components/Tabs/Tabs.vue +++ b/docs/app/pages/Components/Tabs/Tabs.vue @@ -13,35 +13,35 @@
-

Navigational tabs

+

Sometimes you may need a tab to be the main navigational element of your application and you can do this. Tabs integrate with Vue Router by default and will be able to use single tab just like a regular button or link, by using the router-link props. The tabs will sync with the page URL and will produce effects when transitioning between tabs. AUTOMATIC!

-

Tab with inner content

+

Tab with inner content

In the previous example, the tabs worked just like navigation buttons, without content. With that you would need to render the content by yourself. Although this is not a hard thing, because you can use Vue Router, you can pass arbitrary content to your tabs. And it can also work syncing with router:

-

Alignments

+

Alignments

Tabs have four types of alignments for the navigation buttons: Left, Center, Right and Fixed. You can use them with any tabs:

-

Icons

+

Icons

Tabs accept icons, to make it easier for your user to assimilate the contents of a tab:

-

Custom Template

+

Custom Template

You can use a custom template for the navigation buttons. This will be applied to all navigation buttons and allows you to make updates on your tab, like this great example of unread/new content: Simple, uh?

diff --git a/docs/app/pages/Components/Toolbar/Toolbar.vue b/docs/app/pages/Components/Toolbar/Toolbar.vue index 40786a2d3..0662d9a2a 100644 --- a/docs/app/pages/Components/Toolbar/Toolbar.vue +++ b/docs/app/pages/Components/Toolbar/Toolbar.vue @@ -9,7 +9,7 @@
-

Toolbars

+

Toolbars

Toolbars adjusts its height dimensions based on the screen width to best fit the visible area on small devices. Try to resize your browser to see the difference:

@@ -24,13 +24,13 @@
-

Different Sizes

+

Different Sizes

-

Content and Actions

+

Content and Actions

As the Toolbars are mostly used to hold actions that affects the entire application, you can create rows or sections inside of it.

Although those rows works on every toolbar, they were created to separate contents for large toolbars. This element is represented by the md-toolbar-row class. A row can also have a md-toolbar-offset to add a little space on the left of it. This is commonly used inside the second row of an large toolbar.

The sections are used to split the content of the toolbar horizontally (or the row inside). You can apply them using two types of section: md-toolbar-section-start will be left-aligned and md-toolbar-section-end right-aligned.

diff --git a/docs/app/pages/Components/Tooltip/Tooltip.vue b/docs/app/pages/Components/Tooltip/Tooltip.vue index 7f2454e8e..9a973df79 100644 --- a/docs/app/pages/Components/Tooltip/Tooltip.vue +++ b/docs/app/pages/Components/Tooltip/Tooltip.vue @@ -10,20 +10,20 @@
-

Direction

+

Direction

You can set the tooltip direction using the four available values - top, right, bottom and left:

-

Delay

+

Delay

Sometimes you don't want to pop the tooltip right away. To achieve that you can use a custom delay in milliseconds to postpone the action:

-

Dynamically show a tooltip

+

Dynamically show a tooltip

In some cases we may want to trigger the tooltip manually, to make sure that your user will understand and action. You can do it:

diff --git a/docs/app/pages/GettingStarted.vue b/docs/app/pages/GettingStarted.vue index c64c176c8..44804abc1 100644 --- a/docs/app/pages/GettingStarted.vue +++ b/docs/app/pages/GettingStarted.vue @@ -1,9 +1,8 @@