primevue-mirror/pages/theming/index.vue

164 lines
7.4 KiB
Vue
Executable File

<template>
<div>
<Head>
<Title>Theming - PrimeVue</Title>
<Meta name="description" content="Choose from a variety of themes or develop your own theme easily." />
</Head>
<div class="content-section documentation">
<h1>Theming</h1>
<p>Choose from a variety of themes or develop your own theme easily.</p>
<h5>Architecture</h5>
<img alt="Architecture" src="https://primefaces.org/cdn/primevue/images/architecture.jpg" class="architecture-image" />
<p>
PrimeVue is a design agnostic library so unlike other UI libraries it does not enforce a certain styling such as material or bootstrap. In order to achieve this, styling has been separated into core and theme. Core resides inside
PrimeVue to implement the structure of the components such as positioning whereas theme brings the colors, paddings and margins.
</p>
<h5>Themes</h5>
<p>
PrimeVue offers various free themes and premium themes along with premium templates that provide an application layout as well. All the free themes are built with the
<a href="https://www.primefaces.org/designer/primevue">Theme Designer</a> and the npm package brings the CSS output of the theme whereas SCSS is kept as a premium feature in the designer. This means free themes are open source and for
customization with SASS, a designer license needs to be acquired.
</p>
<h5>Customization</h5>
<p>
CSS of the themes share the same license as PrimeVue which is MIT, this means the generated CSS can be customized per your needs however this should be avoided if your customizations are not simple. For instance even to change a
primary color, since there is no variable a find and replace should be performed various times. On the other hand, this can be achieved by changing a single variable e.g. $primaryColor. Visit the
<a href="https://www.primefaces.org/designer/api/primevue/3.9.0">SASS API</a> for the documentation of available customization options.
</p>
<p>
<a href="https://www.primefaces.org/designer/primevue">Designer</a> is the ultimate tool to create your own PrimeVue experience powered by a SASS based theme engine with 500+ variables and a Visual Designer. PrimeVue only ships the
generated CSS of the themes whereas Designer provides full access to the whole SASS structure and the variables of these pre-built themes for easier customization.
</p>
<p>Whether you have your own style guide or just need a custom theme, Designer API is the right tool to design and bring them to existence.</p>
<p>Visit <a href="https://www.primefaces.org/designer/primevue">Designer API HomePage</a> for more information and live demos.</p>
<div class="video-container text-center">
<iframe width="560" height="315" src="https://www.youtube.com/embed/7SqoSutntcE" frameborder="0" allowfullscreen></iframe>
</div>
<a href="http://www.primefaces.org/designer/primevue" class="designer-image">
<img alt="PrimeVue Designer" src="https://primefaces.org/cdn/primevue/images/primevue-designer.jpg" style="width: 100%" />
</a>
<h5>Scaling</h5>
<p>
PrimeVue utilizes rem units to make sure the components blend in with the rest of your UI perfectly. This also enables scaling, for example changing the size of the components is easy as configuring the font size of your document.
Code below sets the scale of the components based on 16px. If you reqire bigger or smaller components, just change this variable and components will scale accordingly.
</p>
<pre v-code.css><code>
html {
font-size: 16px;
}
</code></pre>
<p>Some commonly used components such as inputs, buttons and datatable also provide per component scaling with special classes. Components with specific scaling options are documented in their own documentation.</p>
<pre v-code><code>
&lt;InputText type="text" class="p-inputtext-sm" /&gt;
&lt;Button label="Button" class="p-button-lg" /&gt;
</code></pre>
<h5>Local Styling</h5>
<p>
Theming styles the components globally, in case you required to change the style of a certain component for a specific use case use the class property and override the defaults. Example below changes the background of the panel. Note
that this is only for local styling, if you require to change the background color of all the panels, a custom theme is a far better choice.
</p>
<pre v-code><code>
&lt;Panel header="Custom Header" class="dark-panel"/&gt;
</code></pre>
<pre v-code><code>
&lt;style lang="scss" scoped&gt;
::v-deep(.dark-panel.p-panel) {
.p-panel-titlebar {
background: #212121;
}
}
&lt;/style&gt;
</code></pre>
<h5>Utility Classes</h5>
<p>A couple of utility classes are provided as a solution to common requirements.</p>
<div class="doc-tablewrapper">
<table class="doc-table">
<thead>
<tr>
<th>Name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>p-component</td>
<td>Applies component theming such as font-family and font-size to an element.</td>
</tr>
<tr>
<td>p-disabled</td>
<td>Applies an opacity to display as disabled.</td>
</tr>
<tr>
<td>p-sr-only</td>
<td>Element becomes visually hidden however accessibility is still available.</td>
</tr>
<tr>
<td>p-reset</td>
<td>Resets the browsers defaults.</td>
</tr>
<tr>
<td>p-link</td>
<td>Renders a button as a link.</td>
</tr>
<tr>
<td>p-error</td>
<td>Indicates an error text.</td>
</tr>
<tr>
<td>p-invalid</td>
<td>Styles an form element as invalid.</td>
</tr>
<tr>
<td>p-text-secondary</td>
<td>Applies the text color of the theme with the secondary priority.</td>
</tr>
</tbody>
</table>
</div>
</div>
</div>
</template>
<script>
export default {};
</script>
<style lang="scss" scoped>
.designer-image,
.architecture-image {
width: 75%;
margin: 0 auto;
display: block;
margin-top: 2rem;
margin-bottom: 2rem;
}
@media screen and (max-width: 960px) {
.designer-image,
.architecture-image {
width: 100%;
}
}
</style>