pbiviz new
This commit is contained in:
commit
1c85a515b4
108
.gitignore
vendored
Normal file
108
.gitignore
vendored
Normal file
@ -0,0 +1,108 @@
|
|||||||
|
.vscode/
|
||||||
|
node_modules/
|
||||||
|
dist/
|
||||||
|
webpack.statistics.*
|
||||||
|
# tmp
|
||||||
|
.tmp/
|
||||||
|
|
||||||
|
# Logs
|
||||||
|
logs
|
||||||
|
*.log
|
||||||
|
npm-debug.log*
|
||||||
|
yarn-debug.log*
|
||||||
|
yarn-error.log*
|
||||||
|
lerna-debug.log*
|
||||||
|
|
||||||
|
# Diagnostic reports (https://nodejs.org/api/report.html)
|
||||||
|
report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json
|
||||||
|
|
||||||
|
# Runtime data
|
||||||
|
pids
|
||||||
|
*.pid
|
||||||
|
*.seed
|
||||||
|
*.pid.lock
|
||||||
|
|
||||||
|
# Directory for instrumented libs generated by jscoverage/JSCover
|
||||||
|
lib-cov
|
||||||
|
|
||||||
|
# Coverage directory used by tools like istanbul
|
||||||
|
coverage
|
||||||
|
*.lcov
|
||||||
|
|
||||||
|
# nyc test coverage
|
||||||
|
.nyc_output
|
||||||
|
|
||||||
|
# Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files)
|
||||||
|
.grunt
|
||||||
|
|
||||||
|
# Bower dependency directory (https://bower.io/)
|
||||||
|
bower_components
|
||||||
|
|
||||||
|
# node-waf configuration
|
||||||
|
.lock-wscript
|
||||||
|
|
||||||
|
# Compiled binary addons (https://nodejs.org/api/addons.html)
|
||||||
|
build/Release
|
||||||
|
|
||||||
|
# Dependency directories
|
||||||
|
node_modules/
|
||||||
|
jspm_packages/
|
||||||
|
|
||||||
|
# TypeScript v1 declaration files
|
||||||
|
typings/
|
||||||
|
|
||||||
|
# TypeScript cache
|
||||||
|
*.tsbuildinfo
|
||||||
|
|
||||||
|
# Optional npm cache directory
|
||||||
|
.npm
|
||||||
|
|
||||||
|
# Optional eslint cache
|
||||||
|
.eslintcache
|
||||||
|
|
||||||
|
# Microbundle cache
|
||||||
|
.rpt2_cache/
|
||||||
|
.rts2_cache_cjs/
|
||||||
|
.rts2_cache_es/
|
||||||
|
.rts2_cache_umd/
|
||||||
|
|
||||||
|
# Optional REPL history
|
||||||
|
.node_repl_history
|
||||||
|
|
||||||
|
# Output of 'npm pack'
|
||||||
|
*.tgz
|
||||||
|
|
||||||
|
# Yarn Integrity file
|
||||||
|
.yarn-integrity
|
||||||
|
|
||||||
|
# dotenv environment variables file
|
||||||
|
.env
|
||||||
|
.env.test
|
||||||
|
|
||||||
|
# parcel-bundler cache (https://parceljs.org/)
|
||||||
|
.cache
|
||||||
|
|
||||||
|
# next.js build output
|
||||||
|
.next
|
||||||
|
|
||||||
|
# nuxt.js build output
|
||||||
|
.nuxt
|
||||||
|
|
||||||
|
# gatsby files
|
||||||
|
.cache/
|
||||||
|
public
|
||||||
|
|
||||||
|
# vuepress build output
|
||||||
|
.vuepress/dist
|
||||||
|
|
||||||
|
# Serverless directories
|
||||||
|
.serverless/
|
||||||
|
|
||||||
|
# FuseBox cache
|
||||||
|
.fusebox/
|
||||||
|
|
||||||
|
# DynamoDB Local files
|
||||||
|
.dynamodb/
|
||||||
|
|
||||||
|
# TernJS port file
|
||||||
|
.tern-port
|
BIN
assets/icon.png
Normal file
BIN
assets/icon.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.5 KiB |
84
capabilities.json
Normal file
84
capabilities.json
Normal file
@ -0,0 +1,84 @@
|
|||||||
|
{
|
||||||
|
"dataRoles": [
|
||||||
|
{
|
||||||
|
"displayName": "Category Data",
|
||||||
|
"name": "category",
|
||||||
|
"kind": "Grouping"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"displayName": "Measure Data",
|
||||||
|
"name": "measure",
|
||||||
|
"kind": "Measure"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"objects": {
|
||||||
|
"dataPoint": {
|
||||||
|
"displayName": "Data colors",
|
||||||
|
"properties": {
|
||||||
|
"defaultColor": {
|
||||||
|
"displayName": "Default color",
|
||||||
|
"type": {
|
||||||
|
"fill": {
|
||||||
|
"solid": {
|
||||||
|
"color": true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"showAllDataPoints": {
|
||||||
|
"displayName": "Show all",
|
||||||
|
"type": {
|
||||||
|
"bool": true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"fill": {
|
||||||
|
"displayName": "Fill",
|
||||||
|
"type": {
|
||||||
|
"fill": {
|
||||||
|
"solid": {
|
||||||
|
"color": true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"fillRule": {
|
||||||
|
"displayName": "Color saturation",
|
||||||
|
"type": {
|
||||||
|
"fill": {}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"fontSize": {
|
||||||
|
"displayName": "Text Size",
|
||||||
|
"type": {
|
||||||
|
"formatting": {
|
||||||
|
"fontSize": true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"dataViewMappings": [
|
||||||
|
{
|
||||||
|
"categorical": {
|
||||||
|
"categories": {
|
||||||
|
"for": {
|
||||||
|
"in": "category"
|
||||||
|
},
|
||||||
|
"dataReductionAlgorithm": {
|
||||||
|
"top": {}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"values": {
|
||||||
|
"select": [
|
||||||
|
{
|
||||||
|
"bind": {
|
||||||
|
"to": "measure"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
1102
package-lock.json
generated
Normal file
1102
package-lock.json
generated
Normal file
File diff suppressed because it is too large
Load Diff
24
package.json
Normal file
24
package.json
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
{
|
||||||
|
"name": "visual",
|
||||||
|
"scripts": {
|
||||||
|
"pbiviz": "pbiviz",
|
||||||
|
"start": "pbiviz start",
|
||||||
|
"package": "pbiviz package",
|
||||||
|
"lint": "tslint -c tslint.json -p tsconfig.json"
|
||||||
|
},
|
||||||
|
"dependencies": {
|
||||||
|
"@babel/runtime": "7.6.0",
|
||||||
|
"@babel/runtime-corejs2": "7.6.0",
|
||||||
|
"@types/d3": "5.7.2",
|
||||||
|
"d3": "5.12.0",
|
||||||
|
"powerbi-visuals-utils-dataviewutils": "2.2.1",
|
||||||
|
"powerbi-visuals-api": "~2.6.1",
|
||||||
|
"core-js": "3.2.1"
|
||||||
|
},
|
||||||
|
"devDependencies": {
|
||||||
|
"ts-loader": "6.1.0",
|
||||||
|
"tslint": "^5.18.0",
|
||||||
|
"tslint-microsoft-contrib": "^6.2.0",
|
||||||
|
"typescript": "3.6.3"
|
||||||
|
}
|
||||||
|
}
|
1
pbiviz.json
Normal file
1
pbiviz.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{"visual":{"name":"picsScroller","displayName":"picsScroller","guid":"picsScroller4F6E5B21FAB94F2081F33542CFAD9E09","visualClassName":"Visual","version":"1.0.0","description":"","supportUrl":"","gitHubUrl":""},"apiVersion":"2.6.0","author":{"name":"","email":""},"assets":{"icon":"assets/icon.png"},"externalJS":null,"style":"style/visual.less","capabilities":"capabilities.json","dependencies":null,"stringResources":[]}
|
48
src/settings.ts
Normal file
48
src/settings.ts
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
/*
|
||||||
|
* Power BI Visualizations
|
||||||
|
*
|
||||||
|
* Copyright (c) Microsoft Corporation
|
||||||
|
* All rights reserved.
|
||||||
|
* MIT License
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
* of this software and associated documentation files (the ""Software""), to deal
|
||||||
|
* in the Software without restriction, including without limitation the rights
|
||||||
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
* copies of the Software, and to permit persons to whom the Software is
|
||||||
|
* furnished to do so, subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice shall be included in
|
||||||
|
* all copies or substantial portions of the Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED *AS IS*, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||||
|
* THE SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
import { dataViewObjectsParser } from "powerbi-visuals-utils-dataviewutils";
|
||||||
|
import DataViewObjectsParser = dataViewObjectsParser.DataViewObjectsParser;
|
||||||
|
|
||||||
|
export class VisualSettings extends DataViewObjectsParser {
|
||||||
|
public dataPoint: dataPointSettings = new dataPointSettings();
|
||||||
|
}
|
||||||
|
|
||||||
|
export class dataPointSettings {
|
||||||
|
// Default color
|
||||||
|
public defaultColor: string = "";
|
||||||
|
// Show all
|
||||||
|
public showAllDataPoints: boolean = true;
|
||||||
|
// Fill
|
||||||
|
public fill: string = "";
|
||||||
|
// Color saturation
|
||||||
|
public fillRule: string = "";
|
||||||
|
// Text Size
|
||||||
|
public fontSize: number = 12;
|
||||||
|
}
|
||||||
|
|
81
src/visual.ts
Normal file
81
src/visual.ts
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
/*
|
||||||
|
* Power BI Visual CLI
|
||||||
|
*
|
||||||
|
* Copyright (c) Microsoft Corporation
|
||||||
|
* All rights reserved.
|
||||||
|
* MIT License
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
* of this software and associated documentation files (the ""Software""), to deal
|
||||||
|
* in the Software without restriction, including without limitation the rights
|
||||||
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
* copies of the Software, and to permit persons to whom the Software is
|
||||||
|
* furnished to do so, subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice shall be included in
|
||||||
|
* all copies or substantial portions of the Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED *AS IS*, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||||
|
* THE SOFTWARE.
|
||||||
|
*/
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
import "core-js/stable";
|
||||||
|
import "./../style/visual.less";
|
||||||
|
import powerbi from "powerbi-visuals-api";
|
||||||
|
import VisualConstructorOptions = powerbi.extensibility.visual.VisualConstructorOptions;
|
||||||
|
import VisualUpdateOptions = powerbi.extensibility.visual.VisualUpdateOptions;
|
||||||
|
import IVisual = powerbi.extensibility.visual.IVisual;
|
||||||
|
import EnumerateVisualObjectInstancesOptions = powerbi.EnumerateVisualObjectInstancesOptions;
|
||||||
|
import VisualObjectInstance = powerbi.VisualObjectInstance;
|
||||||
|
import DataView = powerbi.DataView;
|
||||||
|
import VisualObjectInstanceEnumerationObject = powerbi.VisualObjectInstanceEnumerationObject;
|
||||||
|
|
||||||
|
import { VisualSettings } from "./settings";
|
||||||
|
export class Visual implements IVisual {
|
||||||
|
private target: HTMLElement;
|
||||||
|
private updateCount: number;
|
||||||
|
private settings: VisualSettings;
|
||||||
|
private textNode: Text;
|
||||||
|
|
||||||
|
constructor(options: VisualConstructorOptions) {
|
||||||
|
console.log('Visual constructor', options);
|
||||||
|
this.target = options.element;
|
||||||
|
this.updateCount = 0;
|
||||||
|
if (document) {
|
||||||
|
const new_p: HTMLElement = document.createElement("p");
|
||||||
|
new_p.appendChild(document.createTextNode("Update count:"));
|
||||||
|
const new_em: HTMLElement = document.createElement("em");
|
||||||
|
this.textNode = document.createTextNode(this.updateCount.toString());
|
||||||
|
new_em.appendChild(this.textNode);
|
||||||
|
new_p.appendChild(new_em);
|
||||||
|
this.target.appendChild(new_p);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public update(options: VisualUpdateOptions) {
|
||||||
|
this.settings = Visual.parseSettings(options && options.dataViews && options.dataViews[0]);
|
||||||
|
console.log('Visual update', options);
|
||||||
|
if (this.textNode) {
|
||||||
|
this.textNode.textContent = (this.updateCount++).toString();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static parseSettings(dataView: DataView): VisualSettings {
|
||||||
|
return <VisualSettings>VisualSettings.parse(dataView);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This function gets called for each of the objects defined in the capabilities files and allows you to select which of the
|
||||||
|
* objects and properties you want to expose to the users in the property pane.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public enumerateObjectInstances(options: EnumerateVisualObjectInstancesOptions): VisualObjectInstance[] | VisualObjectInstanceEnumerationObject {
|
||||||
|
return VisualSettings.enumerateObjectInstances(this.settings || VisualSettings.getDefault(), options);
|
||||||
|
}
|
||||||
|
}
|
9
style/visual.less
Normal file
9
style/visual.less
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
p {
|
||||||
|
font-size: 20px;
|
||||||
|
font-weight: bold;
|
||||||
|
em {
|
||||||
|
background: yellow;
|
||||||
|
padding: 5px;
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
19
tsconfig.json
Normal file
19
tsconfig.json
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
{
|
||||||
|
"compilerOptions": {
|
||||||
|
"allowJs": false,
|
||||||
|
"emitDecoratorMetadata": true,
|
||||||
|
"experimentalDecorators": true,
|
||||||
|
"target": "es6",
|
||||||
|
"sourceMap": true,
|
||||||
|
"outDir": "./.tmp/build/",
|
||||||
|
"moduleResolution": "node",
|
||||||
|
"declaration": true,
|
||||||
|
"lib": [
|
||||||
|
"es2015",
|
||||||
|
"dom"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"files": [
|
||||||
|
"./src/visual.ts"
|
||||||
|
]
|
||||||
|
}
|
9
tslint.json
Normal file
9
tslint.json
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
{
|
||||||
|
"extends": "tslint-microsoft-contrib/recommended",
|
||||||
|
"rulesDirectory": [
|
||||||
|
"node_modules/tslint-microsoft-contrib"
|
||||||
|
],
|
||||||
|
"rules": {
|
||||||
|
"no-relative-imports": false
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user