Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
48 changes: 44 additions & 4 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@
"igniteui-grid-lite": "^0.6.0",
"igniteui-i18n-resources": "^1.0.2",
"igniteui-theming": "^25.0.0",
"igniteui-webcomponents": "^7.0.0",
"igniteui-webcomponents": "^7.1.0",
"igniteui-webcomponents-charts": "7.0.0",
"igniteui-webcomponents-core": "7.0.0",
"igniteui-webcomponents-dashboards": "7.0.0",
Expand Down
11 changes: 11 additions & 0 deletions samples/layouts/splitter/base/.prettierrc
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
{
"printWidth": 250,
"tabWidth": 4,
"useTabs": false,
"semi": true,
"singleQuote": false,
"trailingComma": "none",
"bracketSpacing": true,
"jsxBracketSameLine": false,
"fluid": false
}
56 changes: 56 additions & 0 deletions samples/layouts/splitter/base/ReadMe.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
<!-- NOTE: do not change this file because it's auto re-generated from template: -->
<!-- https://github.com/IgniteUI/igniteui-wc-examples/tree/vnext/templates/browser/sample/ReadMe.md -->

This folder contains implementation of Web Components application with example of Base feature using [Splitter](https://infragistics.com/webcomponentssite/components/general-getting-started.html) component.


<html lang="en" xmlns="http://www.w3.org/1999/xhtml">
<body>
<a target="_blank" href="https://infragistics.com/webcomponentssite/components/general-getting-started.html" rel="noopener noreferrer">
<img height="40px" style="border-radius: 0rem" alt="View Docs" src="https://dl.infragistics.com/x/img/browsers/button-docs.png"/>
</a>
<a target="_blank" href="./src/index.ts" rel="noopener noreferrer">
<img height="40px" style="border-radius: 0rem; max-width: 100%;" alt="View Code" src="https://dl.infragistics.com/x/img/browsers/button-code.png"/>
</a>
<a target="_blank" href="https://www.infragistics.com/webcomponents-demos/samples/layouts/splitter/base" rel="noopener noreferrer">
<img height="40px" style="border-radius: 0rem; max-width: 100%;" alt="Run Sample" src="https://dl.infragistics.com/x/img/browsers/button-run.png"/>
</a>
<a target="_blank" href="https://codesandbox.io/s/github/IgniteUI/igniteui-wc-examples/tree/master/samples/layouts/splitter/base?fontsize=14&hidenavigation=1&theme=dark&view=preview&file=/src/{SampleFile}" rel="noopener noreferrer">
<img height="40px" style="border-radius: 0rem; max-width: 100%;" alt="Run Sample" src="https://dl.infragistics.com/x/img/browsers/button-sandbox.png"/>
</a>
</body>
</html>

## Branches

> **_NOTE:_** You should use [master](https://github.com/IgniteUI/igniteui-angular-examples/tree/master) branch of this repository if you want to run samples on your computer. Use the [vnext](https://github.com/IgniteUI/igniteui-angular-examples/tree/vnext) branch only when you want to contribute new samples to this repository.

## Instructions

To set up this project locally, execute these commands:

```
git clone https://github.com/IgniteUI/igniteui-wc-examples.git
git checkout master
cd ./igniteui-wc-examples
cd ./samples/layouts/splitter/base
```

open above folder in VS Code or type:
```
code .
```

In terminal window, run:

```
npm install
npm run start
```

Then open http://localhost:4200/ in your browser


## Learn More

To learn more about **Ignite UI for Web Components**, check out the [Web Components documentation](https://infragistics.com/webcomponentssite/components/general-getting-started.html).
41 changes: 41 additions & 0 deletions samples/layouts/splitter/base/index.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
<!DOCTYPE html>
<html>
<head>
<title>Splitter Overview</title>
<meta charset="UTF-8" />

<link rel="shortcut icon" href="https://dl.infragistics.com/x/img/browsers/wc.png" />
<link rel="stylesheet" href="https://fonts.googleapis.com/icon?family=Material+Icons" />
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Kanit&display=swap" />
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Titillium Web" />
<link rel="stylesheet" href="https://dl.infragistics.com/x/css/samples/shared.v8.css" type="text/css" />
</head>

<body>
<div id="root">
<div class="controls">
<igc-switch id="orientationToggle">Make Splitter Vertical</igc-switch>
<igc-switch id="disableCollapseToggle">Disable Collapse</igc-switch>
<igc-switch id="disableResizeToggle">Disable Resize</igc-switch>
<igc-switch id="hideDragHandleToggle">Hide Drag Handle</igc-switch>
<igc-switch id="hideCollapseButtonsToggle">Hide Collapse Buttons</igc-switch>
</div>
<igc-splitter id="splitter" style="height: calc(100vh - 60px); width: 100%;">
<div slot="start">
<p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Mauris in lacus eget turpis congue fermentum. Aliquam sollicitudin massa vel ullamcorper bibendum. Donec sit amet augue in justo fermentum facilisis vel quis quam. Vivamus eget iaculis nisi, vitae dignissim leo. Donec eget consectetur lacus. In viverra vehicula libero, quis dictum odio varius in. Phasellus aliquam elit et lectus ornare placerat. Aliquam vitae sapien facilisis, auctor enim quis, consectetur dui. Cras elementum velit eros, ut efficitur ante pellentesque in. Proin vulputate lacus dui, vitae imperdiet dui pharetra ac. Nunc sagittis, sapien et posuere varius, mauris justo tincidunt odio, in interdum lorem libero sed enim. Nulla placerat scelerisque felis vitae accumsan.
</p>
</div>
<div slot="end">
<p>
Duis auctor, diam id vehicula consequat, lacus tellus molestie magna, sed varius nisi quam eget nisl. Donec dignissim mi et elementum laoreet. Nam dignissim quis justo eu fermentum. Proin vestibulum, neque quis elementum tincidunt, nibh mi gravida purus, eget volutpat ipsum magna in orci. Donec id mauris vitae lectus molestie blandit. Praesent non quam interdum, efficitur lacus nec, gravida mauris. Ut ac ante maximus, ultrices turpis a, aliquam magna. Praesent blandit ante ut nulla malesuada lobortis. Praesent a lobortis justo. Morbi congue, dui sed ornare faucibus, turpis felis vulputate arcu, lobortis posuere sem leo eget risus. Duis risus augue, dignissim ac tincidunt a, ullamcorper rutrum nisl. Ut ut ipsum vel purus viverra dapibus.
</p>
</div>
</igc-splitter>
</div>
<!-- This script is needed only for parcel and it will be excluded for webpack -->
<% if (false) { %>
<script src="src/index.ts"></script>
<% } %>
</body>
</html>
61 changes: 61 additions & 0 deletions samples/layouts/splitter/base/package.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
{
"name": "example-ignite-ui-web-components",
"description": "This project provides example of using Ignite UI for Web Components",
"author": "Infragistics",
"version": "1.0.0",
"license": "",
"private": true,
"homepage": ".",
"main": "src/index.ts",
"scripts": {
"build": "npm run build:prod",
"build:dev": "webpack --mode development --config ./webpack.config.js --progress --color --display-error-details",
"build:prod": "webpack --env.NODE_ENV=production --mode production --config ./webpack.config.js --progress --color --display-error-details --bail",
"serve:dev": "node --max-old-space-size=8192 node_modules/webpack-dev-server/bin/webpack-dev-server.js --mode development --config ./webpack.config.js --hot --progress --open",
"serve:prod": "webpack-dev-server --env.NODE_ENV=production --mode production --config ./webpack.config.js --port 3000 --host 0.0.0.0 --hot --progress --open --content-base dist/",
"start": "npm run serve:dev",
"build:legacy": "npm run build:prod:legacy",
"build:dev:legacy": "webpack --env.legacy=true --mode development --config ./webpack.config.js --progress --color --display-error-details",
"build:prod:legacy": "webpack --env.NODE_ENV=production --env.legacy=true --mode production --config ./webpack.config.js --progress --color --display-error-details --bail",
"serve:dev:legacy": "node --max-old-space-size=8192 node_modules/webpack-dev-server/bin/webpack-dev-server.js --env.legacy=true --mode development --config ./webpack.config.js --hot --progress --open",
"serve:prod:legacy": "webpack-dev-server --env.NODE_ENV=production --env.legacy=true --mode production --config ./webpack.config.js --port 3000 --host 0.0.0.0 --hot --progress --open --content-base dist/",
"start:legacy": "npm run serve:dev:legacy"
},
"dependencies": {
"@webcomponents/custom-elements": "^1.4.1",
"@webcomponents/template": "^1.4.2",
"babel-runtime": "^6.26.0",
"core-js": "^3.6.5",
"igniteui-webcomponents": "^7.1.0",
"lit": "^3.2.0",
"lit-html": "^3.3.1",
"tslib": "^2.8.1"
},
"devDependencies": {
"@babel/cli": "^7.28.3",
"@babel/core": "^7.28.4",
"@babel/plugin-transform-class-properties": "^7.27.1",
"@babel/plugin-transform-class-static-block": "^7.28.3",
"@babel/plugin-transform-runtime": "^7.28.3",
"@babel/preset-env": "^7.28.3",
"@babel/preset-typescript": "^7.27.1",
"@types/source-map": "^0.5.7",
"babel-loader": "^10.0.0",
"babel-plugin-transform-custom-element-classes": "^0.1.0",
"css-loader": "^7.1.2",
"csv-loader": "^3.0.5",
"file-loader": "^6.2.0",
"fork-ts-checker-webpack-plugin": "^9.1.0",
"html-webpack-plugin": "^5.6.4",
"parcel-bundler": "^1.12.5",
"source-map": "^0.7.6",
"style-loader": "^4.0.0",
"tsconfig-paths-webpack-plugin": "^4.2.0",
"typescript": "^5.9.2",
"webpack": "^5.101.3",
"webpack-cli": "^6.0.1",
"webpack-dev-server": "^5.2.2",
"worker-loader": "^3.0.8",
"xml-loader": "^1.2.1"
}
}
7 changes: 7 additions & 0 deletions samples/layouts/splitter/base/sandbox.config.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
{
"infiniteLoopProtection": false,
"hardReloadOnChange": false,
"view": "browser",
"template": "parcel"
}

15 changes: 15 additions & 0 deletions samples/layouts/splitter/base/src/SplitterOverview.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
/* shared styles are loaded from: */
/* https://dl.infragistics.com/x/css/samples/shared.v8.css */
.controls {
display: flex;
flex-wrap: wrap;
gap: 16px;
align-items: center;
padding: 12px 16px;
height: 60px;
box-sizing: border-box;
}

p {
padding: 0 16px;
}
2 changes: 2 additions & 0 deletions samples/layouts/splitter/base/src/index.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
/* shared styles are loaded from: */
/* https://dl.infragistics.com/x/css/samples/shared.v8.css */
35 changes: 35 additions & 0 deletions samples/layouts/splitter/base/src/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
import { defineComponents, IgcSplitterComponent, IgcSwitchComponent } from "igniteui-webcomponents";
import "igniteui-webcomponents/themes/light/bootstrap.css";
import "./SplitterOverview.css";

defineComponents(IgcSplitterComponent, IgcSwitchComponent);

export class SplitterOverview {
private splitter: IgcSplitterComponent;

constructor() {
this.splitter = document.getElementById("splitter") as IgcSplitterComponent;

document.getElementById("orientationToggle")!.addEventListener("igcChange", (e: Event) => {
this.splitter.orientation = (e.target as IgcSwitchComponent).checked ? "vertical" : "horizontal";
});

document.getElementById("disableCollapseToggle")!.addEventListener("igcChange", (e: Event) => {
this.splitter.disableCollapse = (e.target as IgcSwitchComponent).checked;
});

document.getElementById("disableResizeToggle")!.addEventListener("igcChange", (e: Event) => {
this.splitter.disableResize = (e.target as IgcSwitchComponent).checked;
});

document.getElementById("hideDragHandleToggle")!.addEventListener("igcChange", (e: Event) => {
this.splitter.hideDragHandle = (e.target as IgcSwitchComponent).checked;
});

document.getElementById("hideCollapseButtonsToggle")!.addEventListener("igcChange", (e: Event) => {
this.splitter.hideCollapseButtons = (e.target as IgcSwitchComponent).checked;
});
}
}

new SplitterOverview();
20 changes: 20 additions & 0 deletions samples/layouts/splitter/base/tsconfig.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
{
"compilerOptions": {
"noImplicitReturns": true,
"esModuleInterop": true,
"noImplicitAny": true,
"declarationDir": "dist/types",
"moduleResolution": "node",
"declaration": true,
"target": "es2015",
"module": "es2015",
"strict": true
},
"include": [
"src/**/*"
],
"exclude": [
"node_modules",
"dist"
]
}
53 changes: 53 additions & 0 deletions samples/layouts/splitter/base/tslint.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
{
"extends": ["tslint:recommended", "tslint-react", "tslint-config-prettier"],
"linterOptions": {
"exclude": [
"node_modules/**/*.ts",
"**/odatajs-4.0.0.js",
"src/images/*.*"
]
},
"rules": {
"only-arrow-functions": false,
"jsx-self-close": false,
"jsx-wrap-multiline": false,
"no-var-requires": false,
"no-var": false,
"no-var-keyword": false,
"no-console": false,
"no-string-literal": false,
"no-unused-vars": false,
"@typescript-eslint/no-unused-vars": "off",
"jsx-no-lambda": false,
"ordered-imports": false,
"object-literal-sort-keys": false,
"object-literal-shorthand": false,
"member-ordering": false,
"curly": [false, "ignore-same-line"],
"max-classes-per-file": [true, 10],
"prefer-const": false,
"prefer-for-of": false,
"no-useless-constructor": false,
"@typescript-eslint/no-useless-constructor": "off",
"@typescript-eslint/type-annotation-spacing": "off"
},
"jsRules": {
"only-arrow-functions": false,
"jsx-self-close": false,
"jsx-wrap-multiline": false,
"no-var-requires": false,
"no-console": false,
"no-unused-vars": false,
"@typescript-eslint/no-unused-vars": "off",
"jsx-no-lambda": false,
"ordered-imports": false,
"object-literal-sort-keys": false,
"object-literal-shorthand": false,
"curly": [false, "ignore-same-line"],
"max-classes-per-file": [true, 10],
"prefer-const": false,
"prefer-for-of": false,
"no-useless-constructor": false,
"@typescript-eslint/no-useless-constructor": "off"
}
}
Loading
Loading