diff --git a/samples/js-chartist-list/.editorconfig b/samples/js-chartist-list/.editorconfig deleted file mode 100644 index 8ffcdc4ec..000000000 --- a/samples/js-chartist-list/.editorconfig +++ /dev/null @@ -1,25 +0,0 @@ -# EditorConfig helps developers define and maintain consistent -# coding styles between different editors and IDEs -# editorconfig.org - -root = true - - -[*] - -# change these settings to your own preference -indent_style = space -indent_size = 2 - -# we recommend you to keep these unchanged -end_of_line = lf -charset = utf-8 -trim_trailing_whitespace = true -insert_final_newline = true - -[*.md] -trim_trailing_whitespace = false - -[{package,bower}.json] -indent_style = space -indent_size = 2 \ No newline at end of file diff --git a/samples/js-chartist-list/.gitattributes b/samples/js-chartist-list/.gitattributes deleted file mode 100644 index 212566614..000000000 --- a/samples/js-chartist-list/.gitattributes +++ /dev/null @@ -1 +0,0 @@ -* text=auto \ No newline at end of file diff --git a/samples/js-chartist-list/.gitignore b/samples/js-chartist-list/.gitignore deleted file mode 100644 index 63c4ae010..000000000 --- a/samples/js-chartist-list/.gitignore +++ /dev/null @@ -1,32 +0,0 @@ -# Logs -logs -*.log -npm-debug.log* - -# Dependency directories -node_modules - -# Build generated files -dist -lib -solution -temp -*.spapp - -# Coverage directory used by tools like istanbul -coverage - -# OSX -.DS_Store - -# Visual Studio files -.ntvs_analysis.dat -.vs -bin -obj - -# Resx Generated Code -*.resx.ts - -# Styles Generated Code -*.scss.ts diff --git a/samples/js-chartist-list/.npmignore b/samples/js-chartist-list/.npmignore deleted file mode 100644 index 2c93a9384..000000000 --- a/samples/js-chartist-list/.npmignore +++ /dev/null @@ -1,14 +0,0 @@ -# Folders -.vscode -coverage -node_modules -sharepoint -src -temp - -# Files -*.csproj -.git* -.yo-rc.json -gulpfile.js -tsconfig.json diff --git a/samples/js-chartist-list/.vscode/settings.json b/samples/js-chartist-list/.vscode/settings.json deleted file mode 100644 index ab46aaa4f..000000000 --- a/samples/js-chartist-list/.vscode/settings.json +++ /dev/null @@ -1,21 +0,0 @@ -{ - // The number of spaces a tab is equal to. - "editor.tabSize": 2, - - // When enabled, will trim trailing whitespace when you save a file. - "files.trimTrailingWhitespace": true, - - // Controls if the editor should automatically close brackets after opening them - "editor.autoClosingBrackets": false, - - // Configure glob patterns for excluding files and folders. - "search.exclude": { - "**/bower_components": true, - "**/node_modules": true, - "coverage": true, - "dist": true, - "lib-amd": true, - "lib": true, - "temp": true - } -} diff --git a/samples/js-chartist-list/.vscode/tasks.json b/samples/js-chartist-list/.vscode/tasks.json deleted file mode 100644 index 5204908d6..000000000 --- a/samples/js-chartist-list/.vscode/tasks.json +++ /dev/null @@ -1,34 +0,0 @@ -{ - // See http://go.microsoft.com/fwlink/?LinkId=733558 - // for the documentation about the tasks.json format - "version": "0.1.0", - "command": "gulp", - "isShellCommand": true, - "showOutput": "always", - "args": [ - "--no-color" - ], - "tasks": [ - { - "taskName": "bundle", - "isBuildCommand": true, - "problemMatcher": [ - "$tsc" - ] - }, - { - "taskName": "test", - "isTestCommand": true, - "problemMatcher": [ - "$tsc" - ] - }, - { - "taskName": "serve", - "isWatching": true, - "problemMatcher": [ - "$tsc" - ] - } - ] -} diff --git a/samples/js-chartist-list/.yo-rc.json b/samples/js-chartist-list/.yo-rc.json deleted file mode 100644 index eb602e19b..000000000 --- a/samples/js-chartist-list/.yo-rc.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "@microsoft/generator-sharepoint": { - "libraryName": "chart-part", - "libraryId": "0cc6d599-5439-4af6-b7ae-10116ff1b65a", - "framework": "none" - } -} \ No newline at end of file diff --git a/samples/js-chartist-list/README.md b/samples/js-chartist-list/README.md deleted file mode 100644 index c77d41101..000000000 --- a/samples/js-chartist-list/README.md +++ /dev/null @@ -1,26 +0,0 @@ -## chart-part - -This is where you include your web part docs. - -### Building the code - -```bash -git clone the repo -npm i -npm i -g gulp -gulp -``` - -This package produces the following: - -* lib/* commonjs components - this allows this package to be reused from other packages. -* dist/* - a single bundle containing the components used for uploading to a cdn pointing a registered Sharepoint webpart library to. -* example/* a test page that hosts all components in this package. - -### Build options - -gulp nuke - TODO -gulp test - TODO -gulp watch - TODO -gulp build - TODO -gulp deploy - TODO diff --git a/samples/js-chartist-list/chart-part.njsproj b/samples/js-chartist-list/chart-part.njsproj deleted file mode 100644 index b9ee9a184..000000000 --- a/samples/js-chartist-list/chart-part.njsproj +++ /dev/null @@ -1,86 +0,0 @@ - - - - Debug - 2.0 - {0cc6d599-5439-4af6-b7ae-10116ff1b65a} - - ProjectFiles - node_modules\gulp\bin\gulp.js - . - . - {3AF33F2E-1136-4D97-BBB7-1795711AC8B8};{349c5851-65df-11da-9384-00065b846f21};{9092AA53-FB77-4645-B42D-1CCCA6BD08BD} - true - CommonJS - false - 11.0 - $(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v$(VisualStudioVersion) - serve - True - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - False - True - 0 - / - http://localhost:48022/ - False - True - http://localhost:1337 - False - - - - - - - CurrentPage - True - False - False - False - - - - - - - - - False - False - - - - - \ No newline at end of file diff --git a/samples/js-chartist-list/config/config.json b/samples/js-chartist-list/config/config.json deleted file mode 100644 index 8b333cc3a..000000000 --- a/samples/js-chartist-list/config/config.json +++ /dev/null @@ -1,21 +0,0 @@ -{ - "entries": [ - { - "entry": "./lib/webparts/chartPart/ChartPartWebPart.js", - "manifest": "./src/webparts/chartPart/ChartPartWebPart.manifest.json", - "outputPath": "./dist/chart-part.bundle.js" - } - ], - "externals": { - "@microsoft/sp-client-base": "node_modules/@microsoft/sp-client-base/dist/sp-client-base.js", - "@microsoft/sp-client-preview": "node_modules/@microsoft/sp-client-preview/dist/sp-client-preview.js", - "@microsoft/sp-lodash-subset": "node_modules/@microsoft/sp-lodash-subset/dist/sp-lodash-subset.js", - "office-ui-fabric-react": "node_modules/office-ui-fabric-react/dist/office-ui-fabric-react.js", - "react": "node_modules/react/dist/react.min.js", - "react-dom": "node_modules/react-dom/dist/react-dom.min.js", - "react-dom/server": "node_modules/react-dom/dist/react-dom-server.min.js" - }, - "localizedResources": { - "chartPartStrings": "webparts/chartPart/loc/{locale}.js" - } -} diff --git a/samples/js-chartist-list/config/deploy-azure-storage.json b/samples/js-chartist-list/config/deploy-azure-storage.json deleted file mode 100644 index cf8220657..000000000 --- a/samples/js-chartist-list/config/deploy-azure-storage.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "workingDir": "./temp/deploy/", - "account": "", - "container": "chartPart-webpart", - "accessKey": "" -} \ No newline at end of file diff --git a/samples/js-chartist-list/config/package-solution.json b/samples/js-chartist-list/config/package-solution.json deleted file mode 100644 index 6659b2a71..000000000 --- a/samples/js-chartist-list/config/package-solution.json +++ /dev/null @@ -1,10 +0,0 @@ -{ - "solution": { - "name": "chart-part-client-side-solution", - "id": "0cc6d599-5439-4af6-b7ae-10116ff1b65a", - "version": "1.0.0.0" - }, - "paths": { - "zippedPackage": "solution/chart-part.spapp" - } -} diff --git a/samples/js-chartist-list/config/prepare-deploy.json b/samples/js-chartist-list/config/prepare-deploy.json deleted file mode 100644 index 6aca63656..000000000 --- a/samples/js-chartist-list/config/prepare-deploy.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "deployCdnPath": "temp/deploy" -} diff --git a/samples/js-chartist-list/config/serve.json b/samples/js-chartist-list/config/serve.json deleted file mode 100644 index 087899637..000000000 --- a/samples/js-chartist-list/config/serve.json +++ /dev/null @@ -1,9 +0,0 @@ -{ - "port": 4321, - "initialPage": "https://localhost:5432/workbench", - "https": true, - "api": { - "port": 5432, - "entryPath": "node_modules/@microsoft/sp-webpart-workbench/lib/api/" - } -} diff --git a/samples/js-chartist-list/config/tslint.json b/samples/js-chartist-list/config/tslint.json deleted file mode 100644 index bf3362c87..000000000 --- a/samples/js-chartist-list/config/tslint.json +++ /dev/null @@ -1,51 +0,0 @@ -{ - // Display errors as warnings - "displayAsWarning": true, - // The TSLint task may have been configured with several custom lint rules - // before this config file is read (for example lint rules from the tslint-microsoft-contrib - // project). If true, this flag will deactivate any of these rules. - "removeExistingRules": true, - // When true, the TSLint task is configured with some default TSLint "rules.": - "useDefaultConfigAsBase": false, - // Since removeExistingRules=true and useDefaultConfigAsBase=false, there will be no lint rules - // which are active, other than the list of rules below. - "lintConfig": { - // Opt-in to Lint rules which help to eliminate bugs in JavaScript - "rules": { - "class-name": false, - "export-name": false, - "forin": false, - "label-position": false, - "label-undefined": false, - "member-access": true, - "no-arg": false, - "no-console": false, - "no-construct": false, - "no-duplicate-case": true, - "no-duplicate-key": false, - "no-duplicate-variable": true, - "no-eval": false, - "no-function-expression": true, - "no-internal-module": true, - "no-shadowed-variable": true, - "no-switch-case-fall-through": true, - "no-unnecessary-semicolons": true, - "no-unused-expression": true, - "no-unused-imports": true, - "no-unused-variable": true, - "no-unreachable": true, - "no-use-before-declare": true, - "no-with-statement": true, - "semicolon": true, - "trailing-comma": false, - "typedef": false, - "typedef-whitespace": false, - "use-named-parameter": true, - "valid-typeof": true, - "variable-name": false, - "whitespace": false, - "prefer-const": true, - "a11y-role": true - } - } -} \ No newline at end of file diff --git a/samples/js-chartist-list/config/write-manifests.json b/samples/js-chartist-list/config/write-manifests.json deleted file mode 100644 index 0a4bafb06..000000000 --- a/samples/js-chartist-list/config/write-manifests.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "cdnBasePath": "" -} \ No newline at end of file diff --git a/samples/js-chartist-list/gulpfile.js b/samples/js-chartist-list/gulpfile.js deleted file mode 100644 index 7d36ddb1c..000000000 --- a/samples/js-chartist-list/gulpfile.js +++ /dev/null @@ -1,6 +0,0 @@ -'use strict'; - -const gulp = require('gulp'); -const build = require('@microsoft/sp-build-web'); - -build.initialize(gulp); diff --git a/samples/js-chartist-list/package.json b/samples/js-chartist-list/package.json deleted file mode 100644 index 428b62d56..000000000 --- a/samples/js-chartist-list/package.json +++ /dev/null @@ -1,24 +0,0 @@ -{ - "name": "chart-part", - "version": "0.0.1", - "private": true, - "engines": { - "node": ">=0.10.0" - }, - "dependencies": { - "@microsoft/sp-client-base": "~0.3.0", - "@microsoft/sp-client-preview": "~0.4.0", - "chartist": "^0.9.8" - }, - "devDependencies": { - "@microsoft/sp-build-web": "~0.6.0", - "@microsoft/sp-module-interfaces": "~0.3.0", - "@microsoft/sp-webpart-workbench": "~0.4.0", - "gulp": "~3.9.1" - }, - "scripts": { - "build": "gulp bundle", - "clean": "gulp nuke", - "test": "gulp test" - } -} diff --git a/samples/js-chartist-list/readme.txt b/samples/js-chartist-list/readme.txt deleted file mode 100644 index 4b8cc9f9e..000000000 --- a/samples/js-chartist-list/readme.txt +++ /dev/null @@ -1,14 +0,0 @@ -Thanks for downloading the charPart sample! There are a few steps to get set up before the sample will run. - -1) Make sure all the "Set up your development environment" steps have been completed -2) Install the TypeScript Definition Manager for DefinitelyTyped: npm install tsd -g -3) Install the Chartist library by using this command: npm install chartist --save -4) Install the TypeScript type definitions for Chartist: tsd install chartist --save -5) Install the Combokeys type definitions: tsd install combokeys --save -6) In the site on your dev tenant that you plan to run the workbench from create the following columns: - "Level" - Number column - "Topic" - Single line of text column - "Breakout Session Type" - Single line of text column - "Start" - Date and Time column -7) If you want to deploy to CDN please refer to the documentation at http://dev.office.com/sharepoint/docs/spfx/web-parts/get-started/deploy-web-part-to-cdn - diff --git a/samples/js-chartist-list/src/tests.js b/samples/js-chartist-list/src/tests.js deleted file mode 100644 index cb4bb5cf2..000000000 --- a/samples/js-chartist-list/src/tests.js +++ /dev/null @@ -1,5 +0,0 @@ -var context = require.context('.', true, /.+\.test\.js?$/); - -context.keys().forEach(context); - -module.exports = context; diff --git a/samples/js-chartist-list/src/webparts/chartPart/ChartPart.module.scss b/samples/js-chartist-list/src/webparts/chartPart/ChartPart.module.scss deleted file mode 100644 index afc8755d3..000000000 --- a/samples/js-chartist-list/src/webparts/chartPart/ChartPart.module.scss +++ /dev/null @@ -1,21 +0,0 @@ -.chartPart { - .container { - max-width: 700px; - margin: 0px auto; - box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.2), 0 25px 50px 0 rgba(0, 0, 0, 0.1); - } - - .row { - padding: 20px; - } - - .listItem { - max-width: 715px; - margin: 5px auto 5px auto; - box-shadow: 0 0 4px 0 rgba(0, 0, 0, 0.2), 0 25px 50px 0 rgba(0, 0, 0, 0.1); - } - - .button { - text-decoration: none; - } -} diff --git a/samples/js-chartist-list/src/webparts/chartPart/ChartPartWebPart.manifest.json b/samples/js-chartist-list/src/webparts/chartPart/ChartPartWebPart.manifest.json deleted file mode 100644 index 01eac26af..000000000 --- a/samples/js-chartist-list/src/webparts/chartPart/ChartPartWebPart.manifest.json +++ /dev/null @@ -1,23 +0,0 @@ -{ - "$schema": "../../../node_modules/@microsoft/sp-module-interfaces/lib/manifestSchemas/jsonSchemas/clientSideComponentManifestSchema.json", - - "id": "262f2f55-55db-4e03-b1f6-300592ca144e", - "componentType": "WebPart", - "version": "0.0.1", - "manifestVersion": 2, - - "preconfiguredEntries": [{ - "groupId": "262f2f55-55db-4e03-b1f6-300592ca144e", - "group": { "default": "Under Development" }, - "title": { "default": "chartPart" }, - "description": { "default": "Shows a chart from list data" }, - "officeFabricIconFontName": "Page", - "properties": { - "description": "chartPart", - "selectedlist": "", - "whichdata": "Level", - "graphtype": "bargraph", - "graphsize": "ct-perfect-fourth" - } - }] -} diff --git a/samples/js-chartist-list/src/webparts/chartPart/ChartPartWebPart.ts b/samples/js-chartist-list/src/webparts/chartPart/ChartPartWebPart.ts deleted file mode 100644 index 8a67b0232..000000000 --- a/samples/js-chartist-list/src/webparts/chartPart/ChartPartWebPart.ts +++ /dev/null @@ -1,467 +0,0 @@ -import { - BaseClientSideWebPart, - IPropertyPaneSettings, - IWebPartContext, - PropertyPaneTextField, - PropertyPaneDropdown, - IPropertyPaneDropdownOption -} from '@microsoft/sp-client-preview'; - -import styles from './ChartPart.module.scss'; -import * as strings from 'chartPartStrings'; -import { IChartPartWebPartProps } from './IChartPartWebPartProps'; -import MockHttpClient from './MockHttpClient'; -import { EnvironmentType } from '@microsoft/sp-client-base'; -import * as chartistLib from 'chartist'; -import * as moduleLoader from '@microsoft/sp-module-loader'; - -export interface ISPLists { - value: ISPList[]; -} - -export interface ISPList { - Title: string; - Id: string; -} - -export interface ISPListData { - value: Object[]; -} - -export default class ChartPartWebPart extends BaseClientSideWebPart { - - private graphAspectRatios: Array = [ - {key: 'ct-perfect-fourth', text: 'Small'}, - {key: 'ct-golden-section', text: 'Large'}, - {key: 'ct-octave', text: 'Wide'}, - {key: 'ct-double-octave', text: 'Super Wide'}]; - - private graphTypeOptions: Array = [ - {key: 'linegraph', text: 'Line'}, - {key: 'bargraph', text: 'Bar'}, - {key: 'piegraph', text: 'Pie'} - ]; - - private dataTypeOptions: Array = [ - {key: 'Level', text: 'Session Levels'}, - {key: 'Topic', text: 'Session Topics'}, - {key: 'Breakout_x0020_Session_x0020_Typ', text: 'Breakout Session Type'}, - {key: 'Start', text: 'Start Date'} - ]; - - public siteLists: Array = []; - private currentList: Object = null; - private currentListFields: Object[] = []; - private currentListItems: ISPListData = {value: []}; - - private sessionFieldData: chartistLib.IChartistData = {labels: [], series: []}; - private sessionFieldDataPercentages: chartistLib.IChartistData = {labels: [], series: []}; - private totalSessionsWithTargetField: number = 0; - - - public constructor(context: IWebPartContext) { - super(context); - - moduleLoader.default.loadCss('//cdn.jsdelivr.net/chartist.js/latest/chartist.min.css'); - this._initializeLocalData(); - } - -// This gets called after the constructor so we can load the lists from - // SharePoint and be set up before the property pane can open and before - // render is called for the first time. - public onInit(): Promise { - this._initializeDataAsync(); - - return Promise.resolve(); - } - - // Reset all our local storage, we want to do this when we need to re-query - // the server so we start clean. - private _initializeLocalData(): void { - this.currentList = null; - this.currentListFields = null; - this.currentListItems.value = []; - this.sessionFieldData.labels = []; - this.sessionFieldDataPercentages.labels = []; - - this.sessionFieldData.series = []; - (this.sessionFieldData.series as number[][]).push([]); - - this.sessionFieldDataPercentages.series = []; - - this.totalSessionsWithTargetField = 0; - } - - // First initialize the lists and then get the actual list data for the currently selected list. - private _initializeDataAsync(): void { - this._initializeListsAsync(); - if (this.siteLists.length > 0) - { - this._getListDataAsync(this.properties.selectedlist); - } - } - - // If we're in the local Workbench gets mock data, otherwise gets data from SharePoint - private _initializeListsAsync(): void { - // Local environment - if (this.context.environment.type === EnvironmentType.Local) - { - this._getMockLists().then((response) => { - response.value.forEach((item: ISPList) => { - this.siteLists.push({ key: item.Id, text: item.Title }); - }); - }); - } - else - { - const listPromise: Promise = this._getLists(); - if (listPromise != null) - { - listPromise.then((response) => { - response.value.forEach((item: ISPList) => { - this.siteLists.push({ key: item.Id, text: item.Title }); - }); - }); - } - } - } - - // If we're in the local Workbench gets mock data, otherwise gets data from SharePoint - private _getListItemDataAsync(whichList: string): void { - if (this.context.environment.type === EnvironmentType.Local) - { - this._getMockListItems(whichList).then((itemsResponse) => { - for (const item of itemsResponse.value) - { - this.currentListItems.value.push(item); - } - this._processSessionData(); - this.render(); - }); - } - else - { - this._getListItems(whichList, this.properties.whichdata).then((itemsResponse) => { - for (const item of itemsResponse.value) - { - this.currentListItems.value.push(item); - } - this._processSessionData(); - this.render(); - }); - } - } - - // If we're in the local Workbench gets mock data, otherwise gets data from SharePoint - private _getListDataAsync(whichList: string): void { - // Local environment - if (this.context.environment.type === EnvironmentType.Local) { - this._getMockListFields().then((fieldResponse) => { - this.currentListFields = fieldResponse['value']; - - // Check to make sure the current list has the field we want. - if (this._listHasField(this.currentListFields, 'Breakout Session Type')) - { - this._getMockList().then((listResponse) => { - this.currentList = listResponse; - this._getListItemDataAsync(whichList); - }); - } - else { - this.render(); - } - }); } - else { - if (whichList != null && whichList != '') - { - this._getListFields(whichList).then((fieldResponse) => { - this.currentListFields = fieldResponse['value']; - - // Check to make sure the current list has the field we want. - if (this._listHasField(this.currentListFields, 'Breakout Session Type')) - { - this._getList(whichList).then((listResponse) => { - this.currentList = listResponse; - this._getListItemDataAsync(whichList); - }); - } - else { - this.render(); - } - }); - } - } - } - -// Our data access methods, mocks return mock data and not-mocks return live data. - private _getMockLists(): Promise { - return MockHttpClient.get(this.context.pageContext.web.absoluteUrl, 'listoflists').then((data: ISPList[]) => { - var listData: ISPLists = { value: data }; - return listData; - }) as Promise; - } - - private _getMockList(): Promise { - return MockHttpClient.get(this.context.pageContext.web.absoluteUrl, 'listdata').then((data: any) => { - var listData: any = { value: data }; - return listData; - }) as Promise; - } - - private _getMockListFields(): Promise { - return MockHttpClient.get(this.context.pageContext.web.absoluteUrl, 'listfields').then((data: any) => { - var listFields: any = { value: data.value }; - return listFields; - }) as Promise; - } - - private _getMockListItems(whichList: string): Promise { - return MockHttpClient.get(this.context.pageContext.web.absoluteUrl, 'listitemdata').then((data: ISPListData) => { - var listData: ISPListData = { value: data.value }; - return listData; - }) as Promise; - } - - -// #DEMO1 - private _getLists(): Promise { - return this.context.httpClient.get(this.context.pageContext.web.absoluteUrl + `/_api/web/lists?$filter=Hidden eq false`) - .then((response: Response) => { - return response.json(); - }); - } - - private _getList(whichList: string): Promise { - return this.context.httpClient.get(this.context.pageContext.web.absoluteUrl + `/_api/web/lists(guid'` + whichList + `')`) - .then((response: Response) => { - return response.json(); - }); - } - - private _getListFields(whichList: string): Promise { - return this.context.httpClient.get(this.context.pageContext.web.absoluteUrl + `/_api/web/lists(guid'` + whichList + `')/fields?$select=Title`) - .then((response: Response) => { - return response.json(); - }); - } - - private _getListItems(whichList: string, orderby: string): Promise { - return this.context.httpClient.get(this.context.pageContext.web.absoluteUrl + `/_api/web/lists(guid'` + whichList + `')/items?$orderby=` + orderby + ` asc&$top=2000`) - .then((response: Response) => { - return response.json(); - }); - } - - public render(): void { -const chartClass: string = "ct-chart" + this.context.instanceId; - - let selectedDataTypeTitle: string = ""; - let chartHTML: string = "No data to graph, make sure you have a list with the proper schema selected."; - - if (this.currentList != null) - { - for (let i: number = 0; i < this.dataTypeOptions.length; i++) - { - if (this.dataTypeOptions[i].key == this.properties.whichdata) - { - selectedDataTypeTitle = this.dataTypeOptions[i].text; - break; - } - } - - chartHTML = ''; - } - - this.domElement.innerHTML = ` - - - - - ${this.properties.description} - ${selectedDataTypeTitle} - - - ${chartHTML} - - `; - -// #DEMO2 - if (this.currentList != null) - { - if (this.properties.graphtype == 'linegraph') - { - const lineOptions: any = { - // Don't draw the line chart points - showPoint: true, - // Disable line smoothing - lineSmooth: false, - // X-Axis specific configuration - axisX: { - // We can disable the grid for this axis - showGrid: false, - // and also don't show the label - showLabel: true - }, - // Y-Axis specific configuration - axisY: { - // Lets offset the chart a bit from the labels - offset: 60 - } - }; - - let chartistLine: chartistLib.IChartistLineChart; - chartistLine = new chartistLib.Line('.' + chartClass, this.sessionFieldData, lineOptions); - } - else if (this.properties.graphtype == 'bargraph') - { - let chartistBar: chartistLib.IChartistBarChart; - chartistBar = new chartistLib.Bar('.' + chartClass, this.sessionFieldData); - } - else if (this.properties.graphtype == 'piegraph') - { - let chartistPie: chartistLib.IChartistPieChart; - chartistPie = new chartistLib.Pie('.' + chartClass, this.sessionFieldDataPercentages); - } - } - } - - // Property panel methods - protected onPropertyChange(propertyPath: string, newValue: any): void { - if (propertyPath == 'selectedlist') - { - this._initializeLocalData(); - this._getListDataAsync(newValue as string); - } - else if (propertyPath == 'whichdata') - { - this._initializeLocalData(); - this._getListDataAsync(this.properties.selectedlist); - } - - super.onPropertyChange(propertyPath, newValue); - } - - protected get propertyPaneSettings(): IPropertyPaneSettings { - return { - pages: [ - { - header: { - description: strings.PropertyPaneDescription - }, - groups: [ - { - groupName: strings.BasicGroupName, - groupFields: [ - PropertyPaneTextField('description', { - label: strings.DescriptionFieldLabel - }), - PropertyPaneDropdown('selectedlist', { - label: 'Selected List', - options: this.siteLists - }), - PropertyPaneDropdown('whichdata', { - label: 'What kind of data', - options: this.dataTypeOptions - }), - PropertyPaneDropdown('graphtype', { - label: 'Graph Type', - options: this.graphTypeOptions - }), - PropertyPaneDropdown('graphsize', { - label: 'Graph Aspect Ratio (Height:Width)', - options: this.graphAspectRatios - }) - ] - } - ] - } - ] - }; - } - - // Additional business logic methods - private _getFieldDataFromListItem(listItem: Object, itemField: string): string { - let listItemFieldValue: string = ''; - if (listItem.hasOwnProperty(itemField) && listItem[itemField] != null) - { - listItemFieldValue = listItem[itemField]; - } - - return (listItemFieldValue); - } - - private _isFieldRecorded(fieldValue: string): number { - let hasSession: number = -1; - - for (let i: number = 0; i < this.sessionFieldData.labels.length; i++) - { - if (this.sessionFieldData.labels[i] == fieldValue) - { - hasSession = i; - break; - } - } - - return (hasSession); - } - - private _processSessionData(): void { - // Do we have any items? - if (this.currentListItems.value.length > 0) - { - for (const listItem of this.currentListItems.value) - { - let currentValue: string = this._getFieldDataFromListItem(listItem, this.properties.whichdata); - - // If we have a DateTime column, convert it to a real datetime object so we can get the right representation. - if (this.properties.whichdata == 'Start') - { - const tempDateTime: Date = new Date(currentValue); - - if (tempDateTime.toDateString() != 'Invalid Date') - { - currentValue = tempDateTime.toLocaleDateString(); - } - else - { - currentValue = ''; - } - } - - let valueIndex: number = this._isFieldRecorded(currentValue); - if (valueIndex < 0 && currentValue != '') - { - (this.sessionFieldData.labels as string[]).push(currentValue); - (this.sessionFieldData.series[0] as number[]).push(0); - - (this.sessionFieldDataPercentages.labels as string[]).push(currentValue); - (this.sessionFieldDataPercentages.series as number[]).push(0); - - valueIndex = this.sessionFieldData.labels.length - 1; - } - - if (valueIndex >= 0) - { - this.sessionFieldData.series[0][valueIndex]++; - (this.sessionFieldDataPercentages.series as number[])[valueIndex]++; - this.totalSessionsWithTargetField++; - } - } - } - } - - private _listHasField(fieldArray: Object[], whichField: string): boolean { - let hasLevel: boolean = false; - - for (let i: number = 0; i < fieldArray.length; i++) - { - if (fieldArray[i]['Title'] == whichField) - { - hasLevel = true; - break; - } - } - - return (hasLevel); - } -} diff --git a/samples/js-chartist-list/src/webparts/chartPart/IChartPartWebPartProps.ts b/samples/js-chartist-list/src/webparts/chartPart/IChartPartWebPartProps.ts deleted file mode 100644 index 840ea6bb8..000000000 --- a/samples/js-chartist-list/src/webparts/chartPart/IChartPartWebPartProps.ts +++ /dev/null @@ -1,7 +0,0 @@ -export interface IChartPartWebPartProps { - description: string; - selectedlist: string; - whichdata: string; - graphtype: string; - graphsize: string; -} \ No newline at end of file diff --git a/samples/js-chartist-list/src/webparts/chartPart/MockHttpClient.ts b/samples/js-chartist-list/src/webparts/chartPart/MockHttpClient.ts deleted file mode 100644 index 85c55491f..000000000 --- a/samples/js-chartist-list/src/webparts/chartPart/MockHttpClient.ts +++ /dev/null @@ -1,80 +0,0 @@ -import { ISPList } from './ChartPartWebPart'; -import { ISPListData } from './ChartPartWebPart'; - -export default class MockHttpClient { - - private static _listOfLists: ISPList[] = [ - { Title: 'Mock List One', Id: '1' }, - { Title: 'Mock List Two', Id: '2' }, - { Title: 'Mock List Three', Id: '3' } - ]; - - private static _listData: any = [ - { Title: 'Mock List Data', Id: '1' }, - { Title: 'Mock List Data Two', Id: '2' }, - { Title: 'Mock List Data Three', Id: '3' } - ]; - - private static _listItemData: ISPListData = {value: [ - {Level: '100', Topic: 'Mock Topic A', Breakout_x0020_Session_x0020_Typ: 'Mock Session Type Lecture', Start: '9/29/2016'}, - {Level: '100', Topic: 'Mock Topic A', Breakout_x0020_Session_x0020_Typ: 'Mock Session Type Lecture', Start: '9/29/2016'}, - {Level: '200', Topic: 'Mock Topic B', Breakout_x0020_Session_x0020_Typ: 'Mock Session Type Hands on Lab', Start: '9/30/2016'}, - {Level: '300', Topic: 'Mock Topic B', Breakout_x0020_Session_x0020_Typ: 'Mock Session Type Hands on Lab', Start: '9/30/2016'}, - {Level: '400', Topic: 'Mock Topic B', Breakout_x0020_Session_x0020_Typ: 'Mock Session Type Chalktalk', Start: '9/30/2016'}, - {Level: '400', Topic: 'Mock Topic C', Breakout_x0020_Session_x0020_Typ: 'Mock Session Type Chalktalk', Start: '9/30/2016'} - ]}; - - private static _listFields: any = {value: [ - {Title: 'Level'}, - {Title: 'Topic'}, - {Title: 'Breakout_x0020_Session_x0020_Typ'}, - {Title: 'Start'}, - {Title: 'Session ID'} - ]}; - - public static get(restUrl: string, options?: any): Promise { - const optionsString: string = options as string; - - if (optionsString != null) - { - if (optionsString == 'listoflists') - { - return new Promise((resolve) => { - resolve(MockHttpClient._listOfLists); - }); - } - else if (optionsString == 'listdata') - { - return new Promise((resolve) => { - resolve(MockHttpClient._listData); - }); - } - else if (optionsString == 'listitemdata') - { - return new Promise((resolve) => { - resolve(MockHttpClient._listItemData); - }); - } - else if (optionsString == 'listfields') - { - return new Promise((resolve) => { - resolve(MockHttpClient._listFields); - }); - } - else - { - // Assume default is to return the list of lists - return new Promise((resolve) => { - resolve(MockHttpClient._listOfLists); - }); - } - } - else - { - // Assume default is to return the list of lists - return new Promise((resolve) => { - resolve(MockHttpClient._listOfLists); - }); - } - } -} \ No newline at end of file diff --git a/samples/js-chartist-list/src/webparts/chartPart/loc/en-us.js b/samples/js-chartist-list/src/webparts/chartPart/loc/en-us.js deleted file mode 100644 index 89f98bc1e..000000000 --- a/samples/js-chartist-list/src/webparts/chartPart/loc/en-us.js +++ /dev/null @@ -1,7 +0,0 @@ -define([], function() { - return { - "PropertyPaneDescription": "Description", - "BasicGroupName": "Group Name", - "DescriptionFieldLabel": "Description Field" - } -}); \ No newline at end of file diff --git a/samples/js-chartist-list/src/webparts/chartPart/loc/mystrings.d.ts b/samples/js-chartist-list/src/webparts/chartPart/loc/mystrings.d.ts deleted file mode 100644 index 86585c0e4..000000000 --- a/samples/js-chartist-list/src/webparts/chartPart/loc/mystrings.d.ts +++ /dev/null @@ -1,10 +0,0 @@ -declare interface IChartPartStrings { - PropertyPaneDescription: string; - BasicGroupName: string; - DescriptionFieldLabel: string; -} - -declare module 'chartPartStrings' { - const strings: IChartPartStrings; - export = strings; -} diff --git a/samples/js-chartist-list/src/webparts/chartPart/tests/ChartPart.test.ts b/samples/js-chartist-list/src/webparts/chartPart/tests/ChartPart.test.ts deleted file mode 100644 index 0fed73d77..000000000 --- a/samples/js-chartist-list/src/webparts/chartPart/tests/ChartPart.test.ts +++ /dev/null @@ -1,7 +0,0 @@ -import * as assert from 'assert'; - -describe('ChartPartWebPart', () => { - it('should do something', () => { - assert.ok(true); - }); -}); diff --git a/samples/js-chartist-list/tsconfig.json b/samples/js-chartist-list/tsconfig.json deleted file mode 100644 index 98c8662a9..000000000 --- a/samples/js-chartist-list/tsconfig.json +++ /dev/null @@ -1,9 +0,0 @@ -{ - "compilerOptions": { - "target": "es5", - "module": "commonjs", - "jsx": "react", - "declaration": true, - "sourceMap": true - } -} diff --git a/samples/js-chartist-list/tsd.json b/samples/js-chartist-list/tsd.json deleted file mode 100644 index c74548364..000000000 --- a/samples/js-chartist-list/tsd.json +++ /dev/null @@ -1,15 +0,0 @@ -{ - "version": "v4", - "repo": "borisyankov/DefinitelyTyped", - "ref": "master", - "path": "typings", - "bundle": "typings/tsd.d.ts", - "installed": { - "chartist/chartist.d.ts": { - "commit": "8eedd1b9f7f009f14435f73c53a88d537c546a02" - }, - "combokeys/combokeys.d.ts": { - "commit": "8eedd1b9f7f009f14435f73c53a88d537c546a02" - } - } -} diff --git a/samples/js-chartist-list/typings/@ms/odsp-webpack.d.ts b/samples/js-chartist-list/typings/@ms/odsp-webpack.d.ts deleted file mode 100644 index f2b3b03df..000000000 --- a/samples/js-chartist-list/typings/@ms/odsp-webpack.d.ts +++ /dev/null @@ -1,13 +0,0 @@ -// Type definitions for webpack in Microsoft ODSP projects -// Project: ODSP-WEBPACK - -/* - * This definition of webpack require overrides all other definitions of require in our toolchain - * Make sure all other definitions of require are commented out e.g. in node.d.ts - */ -declare var require: { - (path: string): any; - (paths: string[], callback: (...modules: any[]) => void): void; - resolve: (id: string) => string; - ensure: (paths: string[], callback: (require: (path: string) => T) => void, path: string) => void; -}; \ No newline at end of file diff --git a/samples/js-chartist-list/typings/@ms/odsp.d.ts b/samples/js-chartist-list/typings/@ms/odsp.d.ts deleted file mode 100644 index ae3334fe0..000000000 --- a/samples/js-chartist-list/typings/@ms/odsp.d.ts +++ /dev/null @@ -1,10 +0,0 @@ -// Type definitions for Microsoft ODSP projects -// Project: ODSP - -/// - -/* Global definition for DEBUG builds */ -declare const DEBUG: boolean; - -/* Global definition for UNIT_TEST builds */ -declare const UNIT_TEST: boolean; \ No newline at end of file diff --git a/samples/js-chartist-list/typings/assertion-error/assertion-error.d.ts b/samples/js-chartist-list/typings/assertion-error/assertion-error.d.ts deleted file mode 100644 index 08217c9e5..000000000 --- a/samples/js-chartist-list/typings/assertion-error/assertion-error.d.ts +++ /dev/null @@ -1,15 +0,0 @@ -// Type definitions for assertion-error 1.0.0 -// Project: https://github.com/chaijs/assertion-error -// Definitions by: Bart van der Schoor -// Definitions: https://github.com/borisyankov/DefinitelyTyped - -declare module 'assertion-error' { - class AssertionError implements Error { - constructor(message: string, props?: any, ssf?: Function); - name: string; - message: string; - showDiff: boolean; - stack: string; - } - export = AssertionError; -} diff --git a/samples/js-chartist-list/typings/chai/chai.d.ts b/samples/js-chartist-list/typings/chai/chai.d.ts deleted file mode 100644 index da4d718e1..000000000 --- a/samples/js-chartist-list/typings/chai/chai.d.ts +++ /dev/null @@ -1,388 +0,0 @@ -// Type definitions for chai 3.2.0 -// Project: http://chaijs.com/ -// Definitions by: Jed Mao , -// Bart van der Schoor , -// Andrew Brown , -// Olivier Chevet -// Definitions: https://github.com/borisyankov/DefinitelyTyped - -// - -declare module Chai { - - interface ChaiStatic { - expect: ExpectStatic; - should(): Should; - /** - * Provides a way to extend the internals of Chai - */ - use(fn: (chai: any, utils: any) => void): any; - assert: AssertStatic; - config: Config; - AssertionError: AssertionError; - } - - export interface ExpectStatic extends AssertionStatic { - fail(actual?: any, expected?: any, message?: string, operator?: string): void; - } - - export interface AssertStatic extends Assert { - } - - export interface AssertionStatic { - (target: any, message?: string): Assertion; - } - - interface ShouldAssertion { - equal(value1: any, value2: any, message?: string): void; - Throw: ShouldThrow; - throw: ShouldThrow; - exist(value: any, message?: string): void; - } - - interface Should extends ShouldAssertion { - not: ShouldAssertion; - fail(actual: any, expected: any, message?: string, operator?: string): void; - } - - interface ShouldThrow { - (actual: Function): void; - (actual: Function, expected: string|RegExp, message?: string): void; - (actual: Function, constructor: Error|Function, expected?: string|RegExp, message?: string): void; - } - - interface Assertion extends LanguageChains, NumericComparison, TypeComparison { - not: Assertion; - deep: Deep; - any: KeyFilter; - all: KeyFilter; - a: TypeComparison; - an: TypeComparison; - include: Include; - includes: Include; - contain: Include; - contains: Include; - ok: Assertion; - true: Assertion; - false: Assertion; - null: Assertion; - undefined: Assertion; - NaN: Assertion; - exist: Assertion; - empty: Assertion; - arguments: Assertion; - Arguments: Assertion; - equal: Equal; - equals: Equal; - eq: Equal; - eql: Equal; - eqls: Equal; - property: Property; - ownProperty: OwnProperty; - haveOwnProperty: OwnProperty; - ownPropertyDescriptor: OwnPropertyDescriptor; - haveOwnPropertyDescriptor: OwnPropertyDescriptor; - length: Length; - lengthOf: Length; - match: Match; - matches: Match; - string(string: string, message?: string): Assertion; - keys: Keys; - key(string: string): Assertion; - throw: Throw; - throws: Throw; - Throw: Throw; - respondTo: RespondTo; - respondsTo: RespondTo; - itself: Assertion; - satisfy: Satisfy; - satisfies: Satisfy; - closeTo(expected: number, delta: number, message?: string): Assertion; - members: Members; - increase: PropertyChange; - increases: PropertyChange; - decrease: PropertyChange; - decreases: PropertyChange; - change: PropertyChange; - changes: PropertyChange; - extensible: Assertion; - sealed: Assertion; - frozen: Assertion; - - } - - interface LanguageChains { - to: Assertion; - be: Assertion; - been: Assertion; - is: Assertion; - that: Assertion; - which: Assertion; - and: Assertion; - has: Assertion; - have: Assertion; - with: Assertion; - at: Assertion; - of: Assertion; - same: Assertion; - } - - interface NumericComparison { - above: NumberComparer; - gt: NumberComparer; - greaterThan: NumberComparer; - least: NumberComparer; - gte: NumberComparer; - below: NumberComparer; - lt: NumberComparer; - lessThan: NumberComparer; - most: NumberComparer; - lte: NumberComparer; - within(start: number, finish: number, message?: string): Assertion; - } - - interface NumberComparer { - (value: number, message?: string): Assertion; - } - - interface TypeComparison { - (type: string, message?: string): Assertion; - instanceof: InstanceOf; - instanceOf: InstanceOf; - } - - interface InstanceOf { - (constructor: Object, message?: string): Assertion; - } - - interface Deep { - equal: Equal; - include: Include; - property: Property; - members: Members; - } - - interface KeyFilter { - keys: Keys; - } - - interface Equal { - (value: any, message?: string): Assertion; - } - - interface Property { - (name: string, value?: any, message?: string): Assertion; - } - - interface OwnProperty { - (name: string, message?: string): Assertion; - } - - interface OwnPropertyDescriptor { - (name: string, descriptor: PropertyDescriptor, message?: string): Assertion; - (name: string, message?: string): Assertion; - } - - interface Length extends LanguageChains, NumericComparison { - (length: number, message?: string): Assertion; - } - - interface Include { - (value: Object, message?: string): Assertion; - (value: string, message?: string): Assertion; - (value: number, message?: string): Assertion; - keys: Keys; - members: Members; - any: KeyFilter; - all: KeyFilter; - } - - interface Match { - (regexp: RegExp|string, message?: string): Assertion; - } - - interface Keys { - (...keys: string[]): Assertion; - (keys: any[]): Assertion; - (keys: Object): Assertion; - } - - interface Throw { - (): Assertion; - (expected: string, message?: string): Assertion; - (expected: RegExp, message?: string): Assertion; - (constructor: Error, expected?: string, message?: string): Assertion; - (constructor: Error, expected?: RegExp, message?: string): Assertion; - (constructor: Function, expected?: string, message?: string): Assertion; - (constructor: Function, expected?: RegExp, message?: string): Assertion; - } - - interface RespondTo { - (method: string, message?: string): Assertion; - } - - interface Satisfy { - (matcher: Function, message?: string): Assertion; - } - - interface Members { - (set: any[], message?: string): Assertion; - } - - interface PropertyChange { - (object: Object, prop: string, msg?: string): Assertion; - } - - export interface Assert { - /** - * @param expression Expression to test for truthiness. - * @param message Message to display on error. - */ - (expression: any, message?: string): void; - - fail(actual?: any, expected?: any, msg?: string, operator?: string): void; - - ok(val: any, msg?: string): void; - isOk(val: any, msg?: string): void; - notOk(val: any, msg?: string): void; - isNotOk(val: any, msg?: string): void; - - equal(act: any, exp: any, msg?: string): void; - notEqual(act: any, exp: any, msg?: string): void; - - strictEqual(act: any, exp: any, msg?: string): void; - notStrictEqual(act: any, exp: any, msg?: string): void; - - deepEqual(act: any, exp: any, msg?: string): void; - notDeepEqual(act: any, exp: any, msg?: string): void; - - isTrue(val: any, msg?: string): void; - isFalse(val: any, msg?: string): void; - - isNull(val: any, msg?: string): void; - isNotNull(val: any, msg?: string): void; - - isUndefined(val: any, msg?: string): void; - isDefined(val: any, msg?: string): void; - - isNaN(val: any, msg?: string): void; - isNotNaN(val: any, msg?: string): void; - - isAbove(val: number, abv: number, msg?: string): void; - isBelow(val: number, blw: number, msg?: string): void; - - isFunction(val: any, msg?: string): void; - isNotFunction(val: any, msg?: string): void; - - isObject(val: any, msg?: string): void; - isNotObject(val: any, msg?: string): void; - - isArray(val: any, msg?: string): void; - isNotArray(val: any, msg?: string): void; - - isString(val: any, msg?: string): void; - isNotString(val: any, msg?: string): void; - - isNumber(val: any, msg?: string): void; - isNotNumber(val: any, msg?: string): void; - - isBoolean(val: any, msg?: string): void; - isNotBoolean(val: any, msg?: string): void; - - typeOf(val: any, type: string, msg?: string): void; - notTypeOf(val: any, type: string, msg?: string): void; - - instanceOf(val: any, type: Function, msg?: string): void; - notInstanceOf(val: any, type: Function, msg?: string): void; - - include(exp: string, inc: any, msg?: string): void; - include(exp: any[], inc: any, msg?: string): void; - - notInclude(exp: string, inc: any, msg?: string): void; - notInclude(exp: any[], inc: any, msg?: string): void; - - match(exp: any, re: RegExp, msg?: string): void; - notMatch(exp: any, re: RegExp, msg?: string): void; - - property(obj: Object, prop: string, msg?: string): void; - notProperty(obj: Object, prop: string, msg?: string): void; - deepProperty(obj: Object, prop: string, msg?: string): void; - notDeepProperty(obj: Object, prop: string, msg?: string): void; - - propertyVal(obj: Object, prop: string, val: any, msg?: string): void; - propertyNotVal(obj: Object, prop: string, val: any, msg?: string): void; - - deepPropertyVal(obj: Object, prop: string, val: any, msg?: string): void; - deepPropertyNotVal(obj: Object, prop: string, val: any, msg?: string): void; - - lengthOf(exp: any, len: number, msg?: string): void; - //alias frenzy - throw(fn: Function, msg?: string): void; - throw(fn: Function, regExp: RegExp): void; - throw(fn: Function, errType: Function, msg?: string): void; - throw(fn: Function, errType: Function, regExp: RegExp): void; - - throws(fn: Function, msg?: string): void; - throws(fn: Function, regExp: RegExp): void; - throws(fn: Function, errType: Function, msg?: string): void; - throws(fn: Function, errType: Function, regExp: RegExp): void; - - Throw(fn: Function, msg?: string): void; - Throw(fn: Function, regExp: RegExp): void; - Throw(fn: Function, errType: Function, msg?: string): void; - Throw(fn: Function, errType: Function, regExp: RegExp): void; - - doesNotThrow(fn: Function, msg?: string): void; - doesNotThrow(fn: Function, regExp: RegExp): void; - doesNotThrow(fn: Function, errType: Function, msg?: string): void; - doesNotThrow(fn: Function, errType: Function, regExp: RegExp): void; - - operator(val: any, operator: string, val2: any, msg?: string): void; - closeTo(act: number, exp: number, delta: number, msg?: string): void; - - sameMembers(set1: any[], set2: any[], msg?: string): void; - sameDeepMembers(set1: any[], set2: any[], msg?: string): void; - includeMembers(superset: any[], subset: any[], msg?: string): void; - - ifError(val: any, msg?: string): void; - - isExtensible(obj: {}, msg?: string): void; - extensible(obj: {}, msg?: string): void; - isNotExtensible(obj: {}, msg?: string): void; - notExtensible(obj: {}, msg?: string): void; - - isSealed(obj: {}, msg?: string): void; - sealed(obj: {}, msg?: string): void; - isNotSealed(obj: {}, msg?: string): void; - notSealed(obj: {}, msg?: string): void; - - isFrozen(obj: Object, msg?: string): void; - frozen(obj: Object, msg?: string): void; - isNotFrozen(obj: Object, msg?: string): void; - notFrozen(obj: Object, msg?: string): void; - - - } - - export interface Config { - includeStack: boolean; - } - - export class AssertionError { - constructor(message: string, _props?: any, ssf?: Function); - name: string; - message: string; - showDiff: boolean; - stack: string; - } -} - -declare var chai: Chai.ChaiStatic; - -declare module "chai" { - export = chai; -} - -interface Object { - should: Chai.Assertion; -} diff --git a/samples/js-chartist-list/typings/chartist/chartist.d.ts b/samples/js-chartist-list/typings/chartist/chartist.d.ts deleted file mode 100644 index 0e9236481..000000000 --- a/samples/js-chartist-list/typings/chartist/chartist.d.ts +++ /dev/null @@ -1,563 +0,0 @@ -// Type definitions for Chartist v0.9.5 -// Project: https://github.com/gionkunz/chartist-js -// Definitions by: Matt Gibbs -// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped - -declare namespace Chartist { - - interface ChartistStatic { - - /** - * Precision level used internally in Chartist for rounding. If you require more decimal places you can increase this number. - */ - precision: number; - - /** - * A map with characters to escape for strings to be safely used as attribute values. - */ - escapingMap: IChartistEscapeMap; - - Pie: IChartistPieChart; - Bar: IChartistBarChart; - Line: IChartistLineChart; - - FixedScaleAxis: IFixedScaleAxisStatic; - AutoScaleAxis: IAutoScaleAxisStatic; - StepAxis: IStepAxisStatic; - - Svg: ChartistSvgStatic; - Interpolation: ChartistInterpolationStatic; - - noop: Function; - - alphaNumerate(n: number): string; - extend(target: Object, ...sources: Object[]): Object; - - replaceAll(str: string, subStr: string, newSubStr: string): string; - ensureUnit(value: number, unit: string): string; - quantity(input: string | number): Object; - - query(query: Node | string): Node; - times(length: number): Array; - sum(previous: number, current: number): number; - mapMultiply(factor: number): (num: number) => number; - mapAdd(addend: number): (num: number) => number; - serialMap(arr: Array, cb: Function): Array; - roundWithPrecision(value: number, digits?: number): number; - - getMultiValue(value: any, dimension?: any): number; // this method is not documented, but it is used in the examples - - serialize(data: Object | string | number): string; - deserialize(data: string): Object | string | number; - - createSvg(container: Node, width: string, height: string, className: string): Object; // TODO: Figure out if this is returning a ChartistSVGWrapper or an actual SVGElement - - plugins: any; - } - - interface IChartistEscapeMap { - [Key: string]: string; - } - - interface IResponsiveOptionTuple extends Array { - 0: string; - 1: T; - } - - // these have no other purpose than to help define the types that can be placed on - // a line chart axisX - // in the actual chartist library these are classes that project their options onto - // the parent class - interface IFixedScaleAxisStatic { } - interface IAutoScaleAxisStatic { } - interface IStepAxisStatic { } - - // data formats are not well documented on all the ways they can be passed to the constructors - // this definition gives some intellisense, but does not protect the user from misuse - // TODO: come in and tidy this up and make it fit better - interface IChartistData { - labels?: Array | Array | Array; - series: Array | Array | Array>; - } - - interface IChartistSeriesData { - name?: string; - value?: number; - data?: Array; - className?: string; - meta?: string; // I assume this could probably be a number as well? - } - - interface IChartistBase { - container: any; - data: IChartistData; - defaultOptions: T; - options: T; - responsiveOptions: Array>; - - // this most likely doesn't need to be exposed to the user - eventEmitter: any; - - supportsForeignObject: boolean; - supportsAnimations: boolean; - resizeListener: any; - - plugins?: Array; // all of these plugins seem to be functions with options, but keeping type any for now - - update(data: Object, options?: T, override?: boolean): void; - detach(): void; - - /** - * Use this function to register event handlers. The handler callbacks are synchronous and will run in the main thread rather than the event loop. - * - * @method on - * @param event {string} Name of the event. Check the examples for supported events. - * @param handler {Function} The handler function that will be called when an event with the given name was emitted. This function will receive a data argument which contains event data. See the example for more details. - */ - on(event: string, handler: Function): IChartistBase; - - /** - * Use this function to un-register event handlers. If the handler function parameter is omitted all handlers for the given event will be un-registered. - * - * @method off - * @param event {string} Name of the event for which a handler should be removed - * @param handler {Function} The handler function that that was previously used to register a new event handler. This handler will be removed from the event handler list. If this parameter is omitted then all event handlers for the given event are removed from the list. - */ - off(event: string, handler?: Function): IChartistBase; - } - - interface IChartistPieChart extends IChartistBase { - new (target: any, data: IChartistData, options?: IPieChartOptions, responsiveOptions?: Array>): IChartistPieChart; - } - - interface IChartistLineChart extends IChartistBase { - new (target: any, data: IChartistData, options?: ILineChartOptions, responsiveOptions?: Array>): IChartistLineChart; - } - - interface IChartistBarChart extends IChartistBase { - new (target: any, data: IChartistData, options?: IBarChartOptions, responsiveOptions?: Array>): IChartistBarChart; - } - - interface IChartOptions { - /** - * If true the whole data is reversed including labels, the series order as well as the whole series data arrays. - */ - reverseData?: boolean; - - plugins?: Array; - } - - interface IPieChartOptions extends IChartOptions { - /** - * Specify a fixed width for the chart as a string (i.e. '100px' or '50%') - */ - width?: number | string; - - /** - * Specify a fixed height for the chart as a string (i.e. '100px' or '50%') - */ - height?: number | string; - - /** - * Padding of the chart drawing area to the container element and labels as a number or padding object {top: 5, right: 5, bottom: 5, left: 5} - */ - chartPadding?: IChartPadding | number; - - /** - * Override the class names that are used to generate the SVG structure of the chart - */ - classNames?: IPieChartClasses; - - /** - * The start angle of the pie chart in degrees where 0 points north. A higher value offsets the start angle clockwise. - */ - startAngle?: number; - - /** - * An optional total you can specify. By specifying a total value, the sum of the values in the series must be this total in order to draw a full pie. You can use this parameter to draw only parts of a pie or gauge charts. - */ - total?: number; - - /** - * If specified the donut CSS classes will be used and strokes will be drawn instead of pie slices. - */ - donut?: boolean; - - /** - * Specify the donut stroke width, currently done in javascript for convenience. - */ - donutWidth?: number; - - /** - * Specify if a label should be shown or not - */ - showLabel?: boolean; - - /** - * Label position offset from the standard position which is half distance of the radius. This value can be either positive or negative. Positive values will position the label away from the center. - */ - labelOffset?: number; - - /** - * This option can be set to 'inside', 'outside' or 'center'. Positioned with 'inside' the labels will be placed on half the distance of the radius to the border of the Pie by respecting the 'labelOffset'. The 'outside' option will place the labels at the border of the pie and 'center' will place the labels in the absolute center point of the chart. The 'center' option only makes sense in conjunction with the 'labelOffset' option. - */ - labelPosition?: string; - - /** - * An interpolation function for the label value - */ - labelInterpolationFnc?: Function; - - /** - * Label direction can be 'neutral', 'explode' or 'implode'. Default is 'neutral'. The labels anchor will be positioned based on those settings as well as the fact if the labels are on the right or left side of the center of the chart. Usually explode is useful when labels are positioned far away from the center. - */ - labelDirection?: string; - } - - interface IChartPadding { - top?: number; - right?: number; - bottom?: number; - left?: number; - } - - interface IPieChartClasses { - chartPie?: string; - chartDonut?: string; - series?: string; - slicePie?: string; - sliceDonut?: string; - label?: string; - } - - interface IBarChartOptions extends IChartOptions { - axisX?: IBarChartAxis; - axisY?: IBarChartAxis; - width?: number | string; - height?: number | string; - high?: number; - low?: number; - ticks?: Array; - onlyInteger?: boolean; - chartPadding?: IChartPadding; - seriesBarDistance?: number; - - /** - * If set to true this property will cause the series bars to be stacked and form a total for each series point. This will also influence the y-axis and the overall bounds of the chart. In stacked mode the seriesBarDistance property will have no effect. - */ - stackBars?: boolean; - - horizontalBars?: boolean; - distributeSeries?: boolean; - } - - interface IBarChartAxis { - offset?: number; - position?: string; - labelOffset?: { - x?: number; - y?: number; - }; - showLabel?: boolean; - showGrid?: boolean; - labelInterpolationFnc?: Function; - scaleMinSpace?: number; - onlyInteger?: boolean; - } - - interface IBarChartClasses { - chart?: string; - horizontalBars?: string; - label?: string; - labelGroup?: string; - series?: string; - bar?: string; - grid?: string; - gridGroup?: string; - vertical?: string; - horizontal?: string; - start?: string; - end?: string; - } - - interface ILineChartOptions extends IChartOptions { - axisX?: IChartistStepAxis | IChartistFixedScaleAxis | IChartistAutoScaleAxis; - axisY?: IChartistStepAxis | IChartistFixedScaleAxis | IChartistAutoScaleAxis; - width?: number | string; - height?: number | string; - showLine?: boolean; - showPoint?: boolean; - showArea?: boolean; - areaBase?: number; - lineSmooth?: Function | boolean; - low?: number; - high?: number; - ticks?: Array; - chartPadding?: IChartPadding; - fullWidth?: boolean; - classNames?: ILineChartClasses; - } - - interface ILineChartAxis { - offset?: number; - position?: string; - labelOffset?: { - x?: number; - y?: number; - }; - showLabel?: boolean; - showGrid?: boolean; - labelInterpolationFnc?: Function; - } - - interface IChartistStepAxis extends ILineChartAxis { - type?: IStepAxisStatic; - ticks?: Array | Array; - stretch?: boolean; - } - - interface IChartistFixedScaleAxis extends ILineChartAxis { - type?: IFixedScaleAxisStatic; - high?: number; - low?: number; - divisor?: number; - ticks?: Array | Array; - } - - interface IChartistAutoScaleAxis extends ILineChartAxis { - high?: number; - low?: number; - scaleMinSpace?: number; - onlyInteger?: boolean; - referenceValue?: number; - type?: IAutoScaleAxisStatic; - } - - interface ILineChartClasses { - /** - * Default is 'ct-chart-line' - */ - chart?: string; - label?: string; - labelGroup?: string; - series?: string; - line?: string; - point?: string; - area?: string; - grid?: string; - gridGroup?: string; - vertical?: string; - horizontal?: string; - start?: string; - end?: string; - } - - interface ChartistSvgStatic { - new (name: HTMLElement | string, attributes: Object, className?: string, parent?: Object, insertFirst?: boolean): IChartistSvg; - - Easing: ChartistEasingStatic; - - /** - * This method checks for support of a given SVG feature like Extensibility, SVG-animation or the like. Check http://www.w3.org/TR/SVG11/feature for a detailed list. - */ - isSupported(feature: string): boolean; - } - - interface IChartistSvg { - - /** - * Set attributes on the current SVG element of the wrapper you're currently working on. - */ - attr(attributes: Object | string, ns: string): Object | string; - - /** - * Create a new SVG element whose wrapper object will be selected for further operations. This way you can also create nested groups easily. - */ - elem(name: string, attributes?: Object, className?: string, insertFirst?: boolean): IChartistSvg; - - /** - * Returns the parent Chartist.SVG wrapper object - */ - parent(): IChartistSvg; - - /** - * This method returns a Chartist.Svg wrapper around the root SVG element of the current tree. - */ - root(): IChartistSvg; - - /** - * Find the first child SVG element of the current element that matches a CSS selector. The returned object is a Chartist.Svg wrapper. - */ - querySelector(selector: string): IChartistSvg; - - /** - * Find the all child SVG elements of the current element that match a CSS selector. The returned object is a Chartist.Svg.List wrapper. - */ - querySelectorAll(selector: string): any; // this returns an svg wrapper list in the docs, need to see if that's just an array or a special list - - /** - * This method creates a foreignObject (see https://developer.mozilla.org/en-US/docs/Web/SVG/Element/foreignObject) that allows to embed HTML content into a SVG graphic. With the help of foreignObjects you can enable the usage of regular HTML elements inside of SVG where they are subject for SVG positioning and transformation but the Browser will use the HTML rendering capabilities for the containing DOM. - */ - foreignObject(content: any, attributes?: Object, className?: string, insertFirst?: boolean): IChartistSvg; - - /** - * This method adds a new text element to the current Chartist.Svg wrapper. - */ - text(t: string): IChartistSvg; - - /** - * This method will clear all child nodes of the current wrapper object. - */ - empty(): IChartistSvg; - - /** - * This method will cause the current wrapper to remove itself from its parent wrapper. Use this method if you'd like to get rid of an element in a given DOM structure. - */ - remove(): IChartistSvg; - - /** - * This method will replace the element with a new element that can be created outside of the current DOM. - */ - replace(): IChartistSvg; - - /** - * This method will append an element to the current element as a child. - */ - append(): IChartistSvg; - - /** - * Returns an array of class names that are attached to the current wrapper element. This method can not be chained further. - */ - classes(): Array; - - /** - * Adds one or a space separated list of classes to the current element and ensures the classes are only existing once. - * - * @method addClass - * @param names {string} A white space separated list of class names - */ - addClass(names: string): IChartistSvg; - - /** - * Removes one or a space separated list of classes from the current element. - * - * @method removeClass - * @param names {string} A white space separated list of class names - */ - removeClass(names: string): IChartistSvg; - - /** - * Removes all classes from the current element. - */ - removeAllClasses(): IChartistSvg; - - /** - * Get element height with fallback to svg BoundingBox or parent container dimensions - */ - height(): number; - - /** - * The animate function lets you animate the current element with SMIL animations. You can add animations for multiple attributes at the same time by using an animation definition object. This object should contain SMIL animation attributes. - */ - animate(animations: IChartistAnimations, guided: boolean, eventEmitter: Object): IChartistSvg; - - /** - * "Safe" way to get property value from svg BoundingBox. This is a workaround. Firefox throws an NS_ERROR_FAILURE error if getBBox() is called on an invisible node. - * THIS IS A WORKAROUND - */ - getBBoxProperty(node: SVGElement, prop: string): string; // TODO: find a good example of this and add it to the tests, it might belong to static - } - - interface IChartistAnimations { - [Key: string]: IChartistAnimationOptions; - } - - interface IChartistAnimationOptions { - id?: string; - dur: string | number; - from: string | number; - to: string | number; - easing?: IChartistEasingDefinition | string; - fill?: string; - begin?: string; - } - - interface IChartistEasingDefinition { - 0: number; - 1: number; - 2: number; - 3: number; - } - - interface ChartistEasingStatic { - easeInSine: IChartistEasingDefinition; - easeOutSine: IChartistEasingDefinition; - easeInOutSine: IChartistEasingDefinition; - easeInQuad: IChartistEasingDefinition; - easeOutQuad: IChartistEasingDefinition; - easeInOutQuad: IChartistEasingDefinition; - easeInCubic: IChartistEasingDefinition; - easeOutCubic: IChartistEasingDefinition; - easeInOutCubic: IChartistEasingDefinition; - easeInQuart: IChartistEasingDefinition; - easeOutQuart: IChartistEasingDefinition; - easeInOutQuart: IChartistEasingDefinition; - easeInQuint: IChartistEasingDefinition; - easeOutQuint: IChartistEasingDefinition; - easeInOutQuint: IChartistEasingDefinition; - easeInExpo: IChartistEasingDefinition; - easeOutExpo: IChartistEasingDefinition; - easeInOutExpo: IChartistEasingDefinition; - easeInCirc: IChartistEasingDefinition; - easeOutCirc: IChartistEasingDefinition; - easeInOutCirc: IChartistEasingDefinition; - easeInBack: IChartistEasingDefinition; - easeOutBack: IChartistEasingDefinition; - easeInOutBack: IChartistEasingDefinition; - } - - interface ChartistInterpolationStatic { - - /** - * This interpolation function does not smooth the path and the result is only containing lines and no curves. - */ - none(options?: IChartistInterpolationOptions): Function; - - /** - * Simple smoothing creates horizontal handles that are positioned with a fraction of the length between two data points. You can use the divisor option to specify the amount of smoothing. - */ - simple(options?: IChartistSimpleInterpolationOptions): Function; - - /** - * Cardinal / Catmull-Rome spline interpolation is the default smoothing function in Chartist. It produces nice results where the splines will always meet the points. It produces some artifacts though when data values are increased or decreased rapidly. The line may not follow a very accurate path and if the line should be accurate this smoothing function does not produce the best results. - */ - cardinal(options?: IChartistCardinalInterpolationOptions): Function; - - /** - * Step interpolation will cause the line chart to move in steps rather than diagonal or smoothed lines. This interpolation will create additional points that will also be drawn when the showPoint option is enabled. - */ - step(options?: IChartistStepInterpolationOptions): Function; - } - - interface IChartistInterpolationOptions { - fillHoles?: boolean; - } - - interface IChartistSimpleInterpolationOptions extends IChartistInterpolationOptions { - divisor?: number; - } - - interface IChartistCardinalInterpolationOptions extends IChartistInterpolationOptions { - tension?: number; - } - - interface IChartistStepInterpolationOptions extends IChartistInterpolationOptions { - postpone?: boolean; - } -} - -declare var Chartist: Chartist.ChartistStatic; - -declare module 'chartist' { - export = Chartist; -} diff --git a/samples/js-chartist-list/typings/combokeys/combokeys.d.ts b/samples/js-chartist-list/typings/combokeys/combokeys.d.ts deleted file mode 100644 index f7e1e5b03..000000000 --- a/samples/js-chartist-list/typings/combokeys/combokeys.d.ts +++ /dev/null @@ -1,107 +0,0 @@ -// Type definitions for Combokeys v2.4.6 -// Project: https://github.com/PolicyStat/combokeys -// Definitions by: Ian Clanton-Thuon -// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped - -declare namespace Combokeys { - interface CombokeysStatic { - new (element: Element): Combokeys; - - /** - * all instances of Combokeys - */ - instances: Combokeys[]; - - /** - * reset all instances - */ - reset(): void; - } - - interface Combokeys { - element: Element; - - /** - * binds an event to Combokeys - * - * can be a single key, a combination of keys separated with +, - * an array of keys, or a sequence of keys separated by spaces - * - * be sure to list the modifier keys first to make sure that the - * correct key ends up getting bound (the last key in the pattern) - * - * @param {keys} key combination or combinations - * @param {callback} callback function - * @param {handler} optional - one of "keypress", "keydown", or "keyup" - * @returns void - */ - bind(keys: string | string[], callback: () => void, action?: string): void; - - - /** - * binds multiple combinations to the same callback - * - * @param {keys} key combinations - * @param {callback} callback function - * @param {handler} optional - one of "keypress", "keydown", or "keyup" - * @returns void - */ - bindMultiple(keys: string[], callback: () => void, action?: string): void; - - /** - * unbinds an event to Combokeys - * - * the unbinding sets the callback function of the specified key combo - * to an empty function and deletes the corresponding key in the - * directMap dict. - * - * the keycombo+action has to be exactly the same as - * it was defined in the bind method - * - * @param {keys} key combination or combinations - * @param {action} optional - one of "keypress", "keydown", or "keyup" - * @returns void - */ - unbind(keys: string | string[], action?: string): void; - - /** - * triggers an event that has already been bound - * - * @param {keys} key combination - * @param {action} optional - one of "keypress", "keydown", or "keyup" - * @returns void - */ - trigger(keys: string, action?: string): void; - - /** - * resets the library back to its initial state. This is useful - * if you want to clear out the current keyboard shortcuts and bind - * new ones - for example if you switch to another page - * - * @returns void - */ - reset(): void; - - /** - * should we stop this event before firing off callbacks - * - * @param {e} event - * @param {element} bound element - * @return {boolean} - */ - stopCallback(e: Event, element: Element): boolean; - - /** - * detach all listners from the bound element - * - * @return {void} - */ - detach(): void; - } -} - -declare var combokeys: Combokeys.CombokeysStatic; - -declare module "combokeys" { - export = combokeys; -} diff --git a/samples/js-chartist-list/typings/es6-collections/es6-collections.d.ts b/samples/js-chartist-list/typings/es6-collections/es6-collections.d.ts deleted file mode 100644 index bc39df295..000000000 --- a/samples/js-chartist-list/typings/es6-collections/es6-collections.d.ts +++ /dev/null @@ -1,113 +0,0 @@ -// Type definitions for es6-collections v0.5.1 -// Project: https://github.com/WebReflection/es6-collections/ -// Definitions by: Ron Buckton -// Definitions: https://github.com/borisyankov/DefinitelyTyped - -/* ***************************************************************************** -Copyright (c) Microsoft Corporation. All rights reserved. -Licensed under the Apache License, Version 2.0 (the "License"); you may not use -this file except in compliance with the License. You may obtain a copy of the -License at http://www.apache.org/licenses/LICENSE-2.0 - -THIS CODE IS PROVIDED *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY -KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED -WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, -MERCHANTABLITY OR NON-INFRINGEMENT. - -See the Apache Version 2.0 License for specific language governing permissions -and limitations under the License. -***************************************************************************** */ - -interface IteratorResult { - done: boolean; - value?: T; -} - -interface Iterator { - next(value?: any): IteratorResult; - return?(value?: any): IteratorResult; - throw?(e?: any): IteratorResult; -} - -interface ForEachable { - forEach(callbackfn: (value: T) => void): void; -} - -interface Map { - clear(): void; - delete(key: K): boolean; - forEach(callbackfn: (value: V, index: K, map: Map) => void, thisArg?: any): void; - get(key: K): V; - has(key: K): boolean; - set(key: K, value?: V): Map; - entries(): Iterator<[K, V]>; - keys(): Iterator; - values(): Iterator; - size: number; -} - -interface MapConstructor { - new (): Map; - new (iterable: ForEachable<[K, V]>): Map; - prototype: Map; -} - -declare var Map: MapConstructor; - -interface Set { - add(value: T): Set; - clear(): void; - delete(value: T): boolean; - forEach(callbackfn: (value: T, index: T, set: Set) => void, thisArg?: any): void; - has(value: T): boolean; - entries(): Iterator<[T, T]>; - keys(): Iterator; - values(): Iterator; - size: number; -} - -interface SetConstructor { - new (): Set; - new (iterable: ForEachable): Set; - prototype: Set; -} - -declare var Set: SetConstructor; - -interface WeakMap { - delete(key: K): boolean; - clear(): void; - get(key: K): V; - has(key: K): boolean; - set(key: K, value?: V): WeakMap; -} - -interface WeakMapConstructor { - new (): WeakMap; - new (iterable: ForEachable<[K, V]>): WeakMap; - prototype: WeakMap; -} - -declare var WeakMap: WeakMapConstructor; - -interface WeakSet { - delete(value: T): boolean; - clear(): void; - add(value: T): WeakSet; - has(value: T): boolean; -} - -interface WeakSetConstructor { - new (): WeakSet; - new (iterable: ForEachable): WeakSet; - prototype: WeakSet; -} - -declare var WeakSet: WeakSetConstructor; - -declare module "es6-collections" { - var Map: MapConstructor; - var Set: SetConstructor; - var WeakMap: WeakMapConstructor; - var WeakSet: WeakSetConstructor; -} \ No newline at end of file diff --git a/samples/js-chartist-list/typings/es6-promise/es6-promise.d.ts b/samples/js-chartist-list/typings/es6-promise/es6-promise.d.ts deleted file mode 100644 index a8f8d7845..000000000 --- a/samples/js-chartist-list/typings/es6-promise/es6-promise.d.ts +++ /dev/null @@ -1,74 +0,0 @@ -// Type definitions for es6-promise -// Project: https://github.com/jakearchibald/ES6-Promise -// Definitions by: François de Campredon , vvakame -// Definitions: https://github.com/borisyankov/DefinitelyTyped - -interface Thenable { - then(onFulfilled?: (value: R) => U | Thenable, onRejected?: (error: any) => U | Thenable): Thenable; - then(onFulfilled?: (value: R) => U | Thenable, onRejected?: (error: any) => void): Thenable; - catch(onRejected?: (error: any) => U | Thenable): Thenable; -} - -declare class Promise implements Thenable { - /** - * If you call resolve in the body of the callback passed to the constructor, - * your promise is fulfilled with result object passed to resolve. - * If you call reject your promise is rejected with the object passed to reject. - * For consistency and debugging (eg stack traces), obj should be an instanceof Error. - * Any errors thrown in the constructor callback will be implicitly passed to reject(). - */ - constructor(callback: (resolve : (value?: R | Thenable) => void, reject: (error?: any) => void) => void); - - /** - * onFulfilled is called when/if "promise" resolves. onRejected is called when/if "promise" rejects. - * Both are optional, if either/both are omitted the next onFulfilled/onRejected in the chain is called. - * Both callbacks have a single parameter , the fulfillment value or rejection reason. - * "then" returns a new promise equivalent to the value you return from onFulfilled/onRejected after being passed through Promise.resolve. - * If an error is thrown in the callback, the returned promise rejects with that error. - * - * @param onFulfilled called when/if "promise" resolves - * @param onRejected called when/if "promise" rejects - */ - then(onFulfilled?: (value: R) => U | Thenable, onRejected?: (error: any) => U | Thenable): Promise; - then(onFulfilled?: (value: R) => U | Thenable, onRejected?: (error: any) => void): Promise; - - /** - * Sugar for promise.then(undefined, onRejected) - * - * @param onRejected called when/if "promise" rejects - */ - catch(onRejected?: (error: any) => U | Thenable): Promise; -} - -declare module Promise { - /** - * Make a new promise from the thenable. - * A thenable is promise-like in as far as it has a "then" method. - */ - function resolve(value?: R | Thenable): Promise; - - /** - * Make a promise that rejects to obj. For consistency and debugging (eg stack traces), obj should be an instanceof Error - */ - function reject(error: any): Promise; - - /** - * Make a promise that fulfills when every item in the array fulfills, and rejects if (and when) any item rejects. - * the array passed to all can be a mixture of promise-like objects and other objects. - * The fulfillment value is an array (in order) of fulfillment values. The rejection value is the first rejection value. - */ - function all(promises: (R | Thenable)[]): Promise; - - /** - * Make a Promise that fulfills when any item fulfills, and rejects if any item rejects. - */ - function race(promises: (R | Thenable)[]): Promise; -} - -declare module 'es6-promise' { - var foo: typeof Promise; // Temp variable to reference Promise in local context - module rsvp { - export var Promise: typeof foo; - } - export = rsvp; -} diff --git a/samples/js-chartist-list/typings/knockout/knockout.d.ts b/samples/js-chartist-list/typings/knockout/knockout.d.ts deleted file mode 100644 index 267f3174c..000000000 --- a/samples/js-chartist-list/typings/knockout/knockout.d.ts +++ /dev/null @@ -1,631 +0,0 @@ -// Type definitions for Knockout v3.2.0 -// Project: http://knockoutjs.com -// Definitions by: Boris Yankov , Igor Oleinikov , Clément Bourgeois -// Definitions: https://github.com/borisyankov/DefinitelyTyped - - -interface KnockoutSubscribableFunctions { - [key: string]: KnockoutBindingHandler; - - notifySubscribers(valueToWrite?: T, event?: string): void; -} - -interface KnockoutComputedFunctions { - [key: string]: KnockoutBindingHandler; -} - -interface KnockoutObservableFunctions { - [key: string]: KnockoutBindingHandler; - - equalityComparer(a: any, b: any): boolean; -} - -interface KnockoutObservableArrayFunctions { - // General Array functions - indexOf(searchElement: T, fromIndex?: number): number; - slice(start: number, end?: number): T[]; - splice(start: number): T[]; - splice(start: number, deleteCount: number, ...items: T[]): T[]; - pop(): T; - push(...items: T[]): void; - shift(): T; - unshift(...items: T[]): number; - reverse(): KnockoutObservableArray; - sort(): KnockoutObservableArray; - sort(compareFunction: (left: T, right: T) => number): KnockoutObservableArray; - - // Ko specific - [key: string]: KnockoutBindingHandler; - - replace(oldItem: T, newItem: T): void; - - remove(item: T): T[]; - remove(removeFunction: (item: T) => boolean): T[]; - removeAll(items: T[]): T[]; - removeAll(): T[]; - - destroy(item: T): void; - destroy(destroyFunction: (item: T) => boolean): void; - destroyAll(items: T[]): void; - destroyAll(): void; -} - -interface KnockoutSubscribableStatic { - fn: KnockoutSubscribableFunctions; - - new (): KnockoutSubscribable; -} - -interface KnockoutSubscription { - dispose(): void; -} - -interface KnockoutSubscribable extends KnockoutSubscribableFunctions { - subscribe(callback: (newValue: T) => void, target?: any, event?: string): KnockoutSubscription; - subscribe(callback: (newValue: TEvent) => void, target: any, event: string): KnockoutSubscription; - extend(requestedExtenders: { [key: string]: any; }): KnockoutSubscribable; - getSubscriptionsCount(): number; -} - -interface KnockoutComputedStatic { - fn: KnockoutComputedFunctions; - - (): KnockoutComputed; - (func: () => T, context?: any, options?: any): KnockoutComputed; - (def: KnockoutComputedDefine, context?: any): KnockoutComputed; -} - -interface KnockoutComputed extends KnockoutObservable, KnockoutComputedFunctions { - fn: KnockoutComputedFunctions; - - dispose(): void; - isActive(): boolean; - getDependenciesCount(): number; - extend(requestedExtenders: { [key: string]: any; }): KnockoutComputed; -} - -interface KnockoutObservableArrayStatic { - fn: KnockoutObservableArrayFunctions; - - (value?: T[]): KnockoutObservableArray; -} - -interface KnockoutObservableArray extends KnockoutObservable, KnockoutObservableArrayFunctions { - extend(requestedExtenders: { [key: string]: any; }): KnockoutObservableArray; -} - -interface KnockoutObservableStatic { - fn: KnockoutObservableFunctions; - - (value?: T): KnockoutObservable; -} - -interface KnockoutObservable extends KnockoutSubscribable, KnockoutObservableFunctions { - (): T; - (value: T): void; - - peek(): T; - valueHasMutated?:{(): void;}; - valueWillMutate?:{(): void;}; - extend(requestedExtenders: { [key: string]: any; }): KnockoutObservable; -} - -interface KnockoutComputedDefine { - read(): T; - write? (value: T): void; - disposeWhenNodeIsRemoved?: Node; - disposeWhen? (): boolean; - owner?: any; - deferEvaluation?: boolean; - pure?: boolean; -} - -interface KnockoutBindingContext { - $parent: any; - $parents: any[]; - $root: any; - $data: any; - $rawData: any | KnockoutObservable; - $index?: KnockoutObservable; - $parentContext?: KnockoutBindingContext; - $component: any; - $componentTemplateNodes: Node[]; - - extend(properties: any): any; - createChildContext(dataItemOrAccessor: any, dataItemAlias?: any, extendCallback?: Function): any; -} - -interface KnockoutAllBindingsAccessor { - (): any; - get(name: string): any; - has(name: string): boolean; -} - -interface KnockoutBindingHandler { - after?: Array; - init?: (element: any, valueAccessor: () => any, allBindingsAccessor?: KnockoutAllBindingsAccessor, viewModel?: any, bindingContext?: KnockoutBindingContext) => void | { controlsDescendantBindings: boolean; }; - update?: (element: any, valueAccessor: () => any, allBindingsAccessor?: KnockoutAllBindingsAccessor, viewModel?: any, bindingContext?: KnockoutBindingContext) => void; - options?: any; - preprocess?: (value: string, name: string, addBindingCallback?: (name: string, value: string) => void) => string; -} - -interface KnockoutBindingHandlers { - [bindingHandler: string]: KnockoutBindingHandler; - - // Controlling text and appearance - visible: KnockoutBindingHandler; - text: KnockoutBindingHandler; - html: KnockoutBindingHandler; - css: KnockoutBindingHandler; - style: KnockoutBindingHandler; - attr: KnockoutBindingHandler; - - // Control Flow - foreach: KnockoutBindingHandler; - if: KnockoutBindingHandler; - ifnot: KnockoutBindingHandler; - with: KnockoutBindingHandler; - - // Working with form fields - click: KnockoutBindingHandler; - event: KnockoutBindingHandler; - submit: KnockoutBindingHandler; - enable: KnockoutBindingHandler; - disable: KnockoutBindingHandler; - value: KnockoutBindingHandler; - textInput: KnockoutBindingHandler; - hasfocus: KnockoutBindingHandler; - checked: KnockoutBindingHandler; - options: KnockoutBindingHandler; - selectedOptions: KnockoutBindingHandler; - uniqueName: KnockoutBindingHandler; - - // Rendering templates - template: KnockoutBindingHandler; - - // Components (new for v3.2) - component: KnockoutBindingHandler; -} - -interface KnockoutMemoization { - memoize(callback: () => string): string; - unmemoize(memoId: string, callbackParams: any[]): boolean; - unmemoizeDomNodeAndDescendants(domNode: any, extraCallbackParamsArray: any[]): boolean; - parseMemoText(memoText: string): string; -} - -interface KnockoutVirtualElement {} - -interface KnockoutVirtualElements { - allowedBindings: { [bindingName: string]: boolean; }; - emptyNode(node: KnockoutVirtualElement ): void; - firstChild(node: KnockoutVirtualElement ): KnockoutVirtualElement; - insertAfter( container: KnockoutVirtualElement, nodeToInsert: Node, insertAfter: Node ): void; - nextSibling(node: KnockoutVirtualElement): Node; - prepend(node: KnockoutVirtualElement, toInsert: Node ): void; - setDomNodeChildren(node: KnockoutVirtualElement, newChildren: { length: number;[index: number]: Node; } ): void; - childNodes(node: KnockoutVirtualElement ): Node[]; -} - -interface KnockoutExtenders { - throttle(target: any, timeout: number): KnockoutComputed; - notify(target: any, notifyWhen: string): any; - - rateLimit(target: any, timeout: number): any; - rateLimit(target: any, options: { timeout: number; method?: string; }): any; - - trackArrayChanges(target: any): any; -} - -// -// NOTE TO MAINTAINERS AND CONTRIBUTORS : pay attention to only include symbols that are -// publicly exported in the minified version of ko, without that you can give the false -// impression that some functions will be available in production builds. -// -interface KnockoutUtils { - ////////////////////////////////// - // utils.domData.js - ////////////////////////////////// - - domData: { - get (node: Element, key: string): any; - - set (node: Element, key: string, value: any): void; - - getAll(node: Element, createIfNotFound: boolean): any; - - clear(node: Element): boolean; - }; - - ////////////////////////////////// - // utils.domNodeDisposal.js - ////////////////////////////////// - - domNodeDisposal: { - addDisposeCallback(node: Element, callback: Function): void; - - removeDisposeCallback(node: Element, callback: Function): void; - - cleanNode(node: Node): Element; - - removeNode(node: Node): void; - }; - - addOrRemoveItem(array: T[] | KnockoutObservable, value: T, included: T): void; - - arrayFilter(array: T[], predicate: (item: T) => boolean): T[]; - - arrayFirst(array: T[], predicate: (item: T) => boolean, predicateOwner?: any): T; - - arrayForEach(array: T[], action: (item: T, index: number) => void): void; - - arrayGetDistinctValues(array: T[]): T[]; - - arrayIndexOf(array: T[], item: T): number; - - arrayMap(array: T[], mapping: (item: T) => U): U[]; - - arrayPushAll(array: T[] | KnockoutObservableArray, valuesToPush: T[]): T[]; - - arrayRemoveItem(array: any[], itemToRemove: any): void; - - compareArrays(a: T[], b: T[]): Array>; - - extend(target: Object, source: Object): Object; - - fieldsIncludedWithJsonPost: any[]; - - getFormFields(form: any, fieldName: string): any[]; - - objectForEach(obj: any, action: (key: any, value: any) => void): void; - - parseHtmlFragment(html: string): any[]; - - parseJson(jsonString: string): any; - - postJson(urlOrForm: any, data: any, options: any): void; - - peekObservable(value: KnockoutObservable): T; - - range(min: any, max: any): any; - - registerEventHandler(element: any, eventType: any, handler: Function): void; - - setHtml(node: Element, html: () => string): void; - - setHtml(node: Element, html: string): void; - - setTextContent(element: any, textContent: string | KnockoutObservable): void; - - stringifyJson(data: any, replacer?: Function, space?: string): string; - - toggleDomNodeCssClass(node: any, className: string, shouldHaveClass: boolean): void; - - triggerEvent(element: any, eventType: any): void; - - unwrapObservable(value: KnockoutObservable | T): T; - - // NOT PART OF THE MINIFIED API SURFACE (ONLY IN knockout-{version}.debug.js) https://github.com/SteveSanderson/knockout/issues/670 - // forceRefresh(node: any): void; - // ieVersion: number; - // isIe6: boolean; - // isIe7: boolean; - // jQueryHtmlParse(html: string): any[]; - // makeArray(arrayLikeObject: any): any[]; - // moveCleanedNodesToContainerElement(nodes: any[]): HTMLElement; - // replaceDomNodes(nodeToReplaceOrNodeArray: any, newNodesArray: any[]): void; - // setDomNodeChildren(domNode: any, childNodes: any[]): void; - // setElementName(element: any, name: string): void; - // setOptionNodeSelectionState(optionNode: any, isSelected: boolean): void; - // simpleHtmlParse(html: string): any[]; - // stringStartsWith(str: string, startsWith: string): boolean; - // stringTokenize(str: string, delimiter: string): string[]; - // stringTrim(str: string): string; - // tagNameLower(element: any): string; -} - -interface KnockoutArrayChange { - status: string; - value: T; - index: number; - moved?: number; -} - -////////////////////////////////// -// templateSources.js -////////////////////////////////// - -interface KnockoutTemplateSourcesDomElement { - text(): any; - text(value: any): void; - - data(key: string): any; - data(key: string, value: any): any; -} - -interface KnockoutTemplateAnonymous extends KnockoutTemplateSourcesDomElement { - nodes(): any; - nodes(value: any): void; -} - -interface KnockoutTemplateSources { - - domElement: { - prototype: KnockoutTemplateSourcesDomElement - new (element: Element): KnockoutTemplateSourcesDomElement - }; - - anonymousTemplate: { - prototype: KnockoutTemplateAnonymous; - new (element: Element): KnockoutTemplateAnonymous; - }; -} - -////////////////////////////////// -// nativeTemplateEngine.js -////////////////////////////////// - -interface KnockoutNativeTemplateEngine { - - renderTemplateSource(templateSource: Object, bindingContext?: KnockoutBindingContext, options?: Object): any[]; -} - -////////////////////////////////// -// templateEngine.js -////////////////////////////////// - -interface KnockoutTemplateEngine extends KnockoutNativeTemplateEngine { - - createJavaScriptEvaluatorBlock(script: string): string; - - makeTemplateSource(template: any, templateDocument?: Document): any; - - renderTemplate(template: any, bindingContext: KnockoutBindingContext, options: Object, templateDocument: Document): any; - - isTemplateRewritten(template: any, templateDocument: Document): boolean; - - rewriteTemplate(template: any, rewriterCallback: Function, templateDocument: Document): void; -} - -///////////////////////////////// - -interface KnockoutStatic { - utils: KnockoutUtils; - memoization: KnockoutMemoization; - - bindingHandlers: KnockoutBindingHandlers; - getBindingHandler(handler: string): KnockoutBindingHandler; - - virtualElements: KnockoutVirtualElements; - extenders: KnockoutExtenders; - - applyBindings(viewModelOrBindingContext?: any, rootNode?: any): void; - applyBindingsToDescendants(viewModelOrBindingContext: any, rootNode: any): void; - applyBindingAccessorsToNode(node: Node, bindings: (bindingContext: KnockoutBindingContext, node: Node) => {}, bindingContext: KnockoutBindingContext): void; - applyBindingAccessorsToNode(node: Node, bindings: {}, bindingContext: KnockoutBindingContext): void; - applyBindingAccessorsToNode(node: Node, bindings: (bindingContext: KnockoutBindingContext, node: Node) => {}, viewModel: any): void; - applyBindingAccessorsToNode(node: Node, bindings: {}, viewModel: any): void; - applyBindingsToNode(node: Node, bindings: any, viewModelOrBindingContext?: any): any; - - subscribable: KnockoutSubscribableStatic; - observable: KnockoutObservableStatic; - - computed: KnockoutComputedStatic; - pureComputed(evaluatorFunction: () => T, context?: any): KnockoutComputed; - pureComputed(options: KnockoutComputedDefine, context?: any): KnockoutComputed; - - observableArray: KnockoutObservableArrayStatic; - - contextFor(node: any): any; - isSubscribable(instance: any): boolean; - toJSON(viewModel: any, replacer?: Function, space?: any): string; - toJS(viewModel: any): any; - isObservable(instance: any): boolean; - isWriteableObservable(instance: any): boolean; - isComputed(instance: any): boolean; - dataFor(node: any): any; - removeNode(node: Element): void; - cleanNode(node: Element): Element; - renderTemplate(template: Function, viewModel: any, options?: any, target?: any, renderMode?: any): any; - renderTemplate(template: string, viewModel: any, options?: any, target?: any, renderMode?: any): any; - unwrap(value: KnockoutObservable | T): T; - - computedContext: KnockoutComputedContext; - - ////////////////////////////////// - // templateSources.js - ////////////////////////////////// - - templateSources: KnockoutTemplateSources; - - ////////////////////////////////// - // templateEngine.js - ////////////////////////////////// - - templateEngine: { - - prototype: KnockoutTemplateEngine; - - new (): KnockoutTemplateEngine; - }; - - ////////////////////////////////// - // templateRewriting.js - ////////////////////////////////// - - templateRewriting: { - - ensureTemplateIsRewritten(template: Node, templateEngine: KnockoutTemplateEngine, templateDocument: Document): any; - ensureTemplateIsRewritten(template: string, templateEngine: KnockoutTemplateEngine, templateDocument: Document): any; - - memoizeBindingAttributeSyntax(htmlString: string, templateEngine: KnockoutTemplateEngine): any; - - applyMemoizedBindingsToNextSibling(bindings: any, nodeName: string): string; - }; - - ////////////////////////////////// - // nativeTemplateEngine.js - ////////////////////////////////// - - nativeTemplateEngine: { - - prototype: KnockoutNativeTemplateEngine; - - new (): KnockoutNativeTemplateEngine; - - instance: KnockoutNativeTemplateEngine; - }; - - ////////////////////////////////// - // jqueryTmplTemplateEngine.js - ////////////////////////////////// - - jqueryTmplTemplateEngine: { - - prototype: KnockoutTemplateEngine; - - renderTemplateSource(templateSource: Object, bindingContext: KnockoutBindingContext, options: Object): Node[]; - - createJavaScriptEvaluatorBlock(script: string): string; - - addTemplate(templateName: string, templateMarkup: string): void; - }; - - ////////////////////////////////// - // templating.js - ////////////////////////////////// - - setTemplateEngine(templateEngine: KnockoutNativeTemplateEngine): void; - - renderTemplate(template: Function, dataOrBindingContext: KnockoutBindingContext, options: Object, targetNodeOrNodeArray: Node, renderMode: string): any; - renderTemplate(template: any, dataOrBindingContext: KnockoutBindingContext, options: Object, targetNodeOrNodeArray: Node, renderMode: string): any; - renderTemplate(template: Function, dataOrBindingContext: any, options: Object, targetNodeOrNodeArray: Node, renderMode: string): any; - renderTemplate(template: any, dataOrBindingContext: any, options: Object, targetNodeOrNodeArray: Node, renderMode: string): any; - renderTemplate(template: Function, dataOrBindingContext: KnockoutBindingContext, options: Object, targetNodeOrNodeArray: Node[], renderMode: string): any; - renderTemplate(template: any, dataOrBindingContext: KnockoutBindingContext, options: Object, targetNodeOrNodeArray: Node[], renderMode: string): any; - renderTemplate(template: Function, dataOrBindingContext: any, options: Object, targetNodeOrNodeArray: Node[], renderMode: string): any; - renderTemplate(template: any, dataOrBindingContext: any, options: Object, targetNodeOrNodeArray: Node[], renderMode: string): any; - - renderTemplateForEach(template: Function, arrayOrObservableArray: any[], options: Object, targetNode: Node, parentBindingContext: KnockoutBindingContext): any; - renderTemplateForEach(template: any, arrayOrObservableArray: any[], options: Object, targetNode: Node, parentBindingContext: KnockoutBindingContext): any; - renderTemplateForEach(template: Function, arrayOrObservableArray: KnockoutObservable, options: Object, targetNode: Node, parentBindingContext: KnockoutBindingContext): any; - renderTemplateForEach(template: any, arrayOrObservableArray: KnockoutObservable, options: Object, targetNode: Node, parentBindingContext: KnockoutBindingContext): any; - - expressionRewriting: { - bindingRewriteValidators: any; - parseObjectLiteral: { (objectLiteralString: string): any[] } - }; - - ///////////////////////////////// - - bindingProvider: { - instance: KnockoutBindingProvider; - new (): KnockoutBindingProvider; - } - - ///////////////////////////////// - // selectExtensions.js - ///////////////////////////////// - - selectExtensions: { - - readValue(element: HTMLElement): any; - - writeValue(element: HTMLElement, value: any): void; - }; - - components: KnockoutComponents; -} - -interface KnockoutBindingProvider { - nodeHasBindings(node: Node): boolean; - getBindings(node: Node, bindingContext: KnockoutBindingContext): {}; - getBindingAccessors?(node: Node, bindingContext: KnockoutBindingContext): { [key: string]: string; }; -} - -interface KnockoutComputedContext { - getDependenciesCount(): number; - isInitial: () => boolean; - isSleeping: boolean; -} - -// -// refactored types into a namespace to reduce global pollution -// and used Union Types to simplify overloads (requires TypeScript 1.4) -// -declare module KnockoutComponentTypes { - - interface Config { - viewModel?: ViewModelFunction | ViewModelSharedInstance | ViewModelFactoryFunction | AMDModule; - template: string | Node[]| DocumentFragment | TemplateElement | AMDModule; - synchronous?: boolean; - } - - interface ComponentConfig { - viewModel?: ViewModelFunction | ViewModelSharedInstance | ViewModelFactoryFunction | AMDModule; - template: any; - createViewModel?: any; - } - - interface EmptyConfig { - } - - // common AMD type - interface AMDModule { - require: string; - } - - // viewmodel types - interface ViewModelFunction { - (params?: any): any; - } - - interface ViewModelSharedInstance { - instance: any; - } - - interface ViewModelFactoryFunction { - createViewModel: (params?: any, componentInfo?: ComponentInfo) => any; - } - - interface ComponentInfo { - element: Node; - templateNodes: Node[]; - } - - interface TemplateElement { - element: string | Node; - } - - interface Loader { - getConfig? (componentName: string, callback: (result: ComponentConfig) => void): void; - loadComponent? (componentName: string, config: ComponentConfig, callback: (result: Definition) => void): void; - loadTemplate? (componentName: string, templateConfig: any, callback: (result: Node[]) => void): void; - loadViewModel? (componentName: string, viewModelConfig: any, callback: (result: any) => void): void; - suppressLoaderExceptions?: boolean; - } - - interface Definition { - template: Node[]; - createViewModel? (params: any, options: { element: Node; }): any; - } -} - -interface KnockoutComponents { - // overloads for register method: - register(componentName: string, config: KnockoutComponentTypes.Config | KnockoutComponentTypes.EmptyConfig): void; - - isRegistered(componentName: string): boolean; - unregister(componentName: string): void; - get(componentName: string, callback: (definition: KnockoutComponentTypes.Definition) => void): void; - clearCachedDefinition(componentName: string): void - defaultLoader: KnockoutComponentTypes.Loader; - loaders: KnockoutComponentTypes.Loader[]; - getComponentNameForNode(node: Node): string; -} - -declare var ko: KnockoutStatic; - -declare module "knockout" { - export = ko; -} diff --git a/samples/js-chartist-list/typings/lodash/lodash.d.ts b/samples/js-chartist-list/typings/lodash/lodash.d.ts deleted file mode 100644 index 1e39d223f..000000000 --- a/samples/js-chartist-list/typings/lodash/lodash.d.ts +++ /dev/null @@ -1,20808 +0,0 @@ -// Type definitions for Lo-Dash -// Project: http://lodash.com/ -// Definitions by: Brian Zengel , Ilya Mochalov , Stepan Mikhaylyuk -// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped - - -/** -### 4.0.0 Changelog (https://github.com/lodash/lodash/wiki/Changelog) - -#### TODO: -removed: -- [x] Removed _.support -- [x] Removed _.findWhere in favor of _.find with iteratee shorthand -- [x] Removed _.where in favor of _.filter with iteratee shorthand -- [x] Removed _.pluck in favor of _.map with iteratee shorthand - -renamed: -- [x] Renamed _.first to _.head -- [x] Renamed _.indexBy to _.keyBy -- [x] Renamed _.invoke to _.invokeMap -- [x] Renamed _.overArgs to _.overArgs -- [x] Renamed _.padLeft & _.padRight to _.padStart & _.padEnd -- [x] Renamed _.pairs to _.toPairs -- [x] Renamed _.rest to _.tail -- [x] Renamed _.restParam to _.rest -- [x] Renamed _.sortByOrder to _.orderBy -- [x] Renamed _.trimLeft & _.trimRight to _.trimStart & _.trimEnd -- [x] Renamed _.trunc to _.truncate - -split: -- [x] Split _.indexOf & _.lastIndexOf into _.sortedIndexOf & _.sortedLastIndexOf -- [x] Split _.max & _.min into _.maxBy & _.minBy -- [x] Split _.omit & _.pick into _.omitBy & _.pickBy -- [x] Split _.sample into _.sampleSize -- [x] Split _.sortedIndex into _.sortedIndexBy -- [x] Split _.sortedLastIndex into _.sortedLastIndexBy -- [x] Split _.uniq into _.sortedUniq, _.sortedUniqBy, & _.uniqBy - -changes: -- [x] Absorbed _.sortByAll into _.sortBy -- [x] Changed the category of _.at to “Object” -- [x] Changed the category of _.bindAll to “Utility” -- [x] Made _.capitalize uppercase the first character & lowercase the rest -- [x] Made _.functions return only own method names - - -added 23 array methods: -- [x] _.concat -- [x] _.differenceBy -- [x] _.differenceWith -- [x] _.flatMap -- [x] _.fromPairs -- [x] _.intersectionBy -- [x] _.intersectionWith -- [x] _.join -- [x] _.pullAll -- [x] _.pullAllBy -- [x] _.reverse -- [x] _.sortedIndexBy -- [x] _.sortedIndexOf -- [x] _.sortedLastIndexBy -- [x] _.sortedLastIndexOf -- [x] _.sortedUniq -- [x] _.sortedUniqBy -- [x] _.unionBy -- [x] _.unionWith -- [x] _.uniqBy -- [x] _.uniqWith -- [x] _.xorBy -- [x] _.xorWith - -added 18 lang methods: -- [x] _.cloneDeepWith -- [x] _.cloneWith -- [x] _.eq -- [x] _.isArrayLike -- [x] _.isArrayLikeObject -- [x] _.isEqualWith -- [x] _.isInteger -- [x] _.isLength -- [x] _.isMatchWith -- [x] _.isNil -- [x] _.isObjectLike -- [x] _.isSafeInteger -- [x] _.isSymbol -- [x] _.toInteger -- [x] _.toLength -- [x] _.toNumber -- [x] _.toSafeInteger -- [x] _.toString - -added 13 object methods: -- [x] _.assignIn -- [x] _.assignInWith -- [x] _.assignWith -- [x] _.functionsIn -- [x] _.hasIn -- [x] _.mergeWith -- [x] _.omitBy -- [x] _.pickBy - - -added 8 string methods: -- [x] _.lowerCase -- [x] _.lowerFirst -- [x] _.upperCase -- [x] _.upperFirst -- [x] _.toLower -- [x] _.toUpper - -added 8 utility methods: -- [x] _.toPath - -added 4 math methods: -- [x] _.maxBy -- [x] _.mean -- [x] _.minBy -- [x] _.sumBy - -added 2 function methods: -- [x] _.flip -- [x] _.unary - -added 2 number methods: -- [x] _.clamp -- [x] _.subtract - -added collection method: -- [x] _.sampleSize - -Added 3 aliases - -- [x] _.first as an alias of _.head - -Removed 17 aliases -- [x] Removed aliase _.all -- [x] Removed aliase _.any -- [x] Removed aliase _.backflow -- [x] Removed aliase _.callback -- [x] Removed aliase _.collect -- [x] Removed aliase _.compose -- [x] Removed aliase _.contains -- [x] Removed aliase _.detect -- [x] Removed aliase _.foldl -- [x] Removed aliase _.foldr -- [x] Removed aliase _.include -- [x] Removed aliase _.inject -- [x] Removed aliase _.methods -- [x] Removed aliase _.object -- [x] Removed aliase _.run -- [x] Removed aliase _.select -- [x] Removed aliase _.unique - -Other changes -- [x] Added support for array buffers to _.isEqual -- [x] Added support for converting iterators to _.toArray -- [x] Added support for deep paths to _.zipObject -- [x] Changed UMD to export to window or self when available regardless of other exports -- [x] Ensured debounce cancel clears args & thisArg references -- [x] Ensured _.add, _.subtract, & _.sum don’t skip NaN values -- [x] Ensured _.clone treats generators like functions -- [x] Ensured _.clone produces clones with the source’s [[Prototype]] -- [x] Ensured _.defaults assigns properties that shadow Object.prototype -- [x] Ensured _.defaultsDeep doesn’t merge a string into an array -- [x] Ensured _.defaultsDeep & _.merge don’t modify sources -- [x] Ensured _.defaultsDeep works with circular references -- [x] Ensured _.keys skips “length” on strict mode arguments objects in Safari 9 -- [x] Ensured _.merge doesn’t convert strings to arrays -- [x] Ensured _.merge merges plain-objects onto non plain-objects -- [x] Ensured _#plant resets iterator data of cloned sequences -- [x] Ensured _.random swaps min & max if min is greater than max -- [x] Ensured _.range preserves the sign of start of -0 -- [x] Ensured _.reduce & _.reduceRight use getIteratee in their array branch -- [x] Fixed rounding issue with the precision param of _.floor - -** LATER ** -Misc: -- [ ] Made _.forEach, _.forIn, _.forOwn, & _.times implicitly end a chain sequence -- [ ] Removed thisArg params from most methods -- [ ] Made “By” methods provide a single param to iteratees -- [ ] Made _.words chainable by default -- [ ] Removed isDeep params from _.clone & _.flatten -- [ ] Removed _.bindAll support for binding all methods when no names are provided -- [ ] Removed func-first param signature from _.before & _.after -- [ ] _.extend as an alias of _.assignIn -- [ ] _.extendWith as an alias of _.assignInWith -- [ ] Added clear method to _.memoize.Cache -- [ ] Added flush method to debounced & throttled functions -- [ ] Added support for ES6 maps, sets, & symbols to _.clone, _.isEqual, & _.toArray -- [ ] Enabled _.flow & _.flowRight to accept an array of functions -- [ ] Ensured “Collection” methods treat functions as objects -- [ ] Ensured _.assign, _.defaults, & _.merge coerce object values to objects -- [ ] Ensured _.bindKey bound functions call object[key] when called with the new operator -- [ ] Ensured _.isFunction returns true for generator functions -- [ ] Ensured _.merge assigns typed arrays directly -- [ ] Made _(...) an iterator & iterable -- [ ] Made _.drop, _.take, & right forms coerce n of undefined to 0 - -Methods: -- [ ] _.concat -- [ ] _.differenceBy -- [ ] _.differenceWith -- [ ] _.flatMap -- [ ] _.fromPairs -- [ ] _.intersectionBy -- [ ] _.intersectionWith -- [ ] _.join -- [ ] _.pullAll -- [ ] _.pullAllBy -- [ ] _.reverse -- [ ] _.sortedLastIndexOf -- [ ] _.unionBy -- [ ] _.unionWith -- [ ] _.uniqWith -- [ ] _.xorBy -- [ ] _.xorWith -- [ ] _.toString - -- [ ] _.invoke -- [ ] _.setWith -- [ ] _.toPairs -- [ ] _.toPairsIn -- [ ] _.unset - -- [ ] _.replace -- [ ] _.split - -- [ ] _.cond -- [ ] _.conforms -- [ ] _.nthArg -- [ ] _.over -- [ ] _.overEvery -- [ ] _.overSome -- [ ] _.rangeRight - -- [ ] _.next -*/ - -declare var _: _.LoDashStatic; - -declare module _ { - interface LoDashStatic { - /** - * Creates a lodash object which wraps the given value to enable intuitive method chaining. - * - * In addition to Lo-Dash methods, wrappers also have the following Array methods: - * concat, join, pop, push, reverse, shift, slice, sort, splice, and unshift - * - * Chaining is supported in custom builds as long as the value method is implicitly or - * explicitly included in the build. - * - * The chainable wrapper functions are: - * after, assign, bind, bindAll, bindKey, chain, chunk, compact, compose, concat, countBy, - * createCallback, curry, debounce, defaults, defer, delay, difference, filter, flatten, - * forEach, forEachRight, forIn, forInRight, forOwn, forOwnRight, functions, groupBy, - * keyBy, initial, intersection, invert, invoke, keys, map, max, memoize, merge, min, - * object, omit, once, pairs, partial, partialRight, pick, pluck, pull, push, range, reject, - * remove, rest, reverse, sample, shuffle, slice, sort, sortBy, splice, tap, throttle, times, - * toArray, transform, union, uniq, unset, unshift, unzip, values, where, without, wrap, and zip - * - * The non-chainable wrapper functions are: - * clone, cloneDeep, contains, escape, every, find, findIndex, findKey, findLast, - * findLastIndex, findLastKey, has, identity, indexOf, isArguments, isArray, isBoolean, - * isDate, isElement, isEmpty, isEqual, isFinite, isFunction, isNaN, isNull, isNumber, - * isObject, isPlainObject, isRegExp, isString, isUndefined, join, lastIndexOf, mixin, - * noConflict, parseInt, pop, random, reduce, reduceRight, result, shift, size, some, - * sortedIndex, runInContext, template, unescape, uniqueId, and value - * - * The wrapper functions first and last return wrapped values when n is provided, otherwise - * they return unwrapped values. - * - * Explicit chaining can be enabled by using the _.chain method. - **/ - (value: number): LoDashImplicitWrapper; - (value: string): LoDashImplicitStringWrapper; - (value: boolean): LoDashImplicitWrapper; - (value: Array): LoDashImplicitNumberArrayWrapper; - (value: Array): LoDashImplicitArrayWrapper; - (value: T): LoDashImplicitObjectWrapper; - (value: any): LoDashImplicitWrapper; - - /** - * The semantic version number. - **/ - VERSION: string; - - /** - * By default, the template delimiters used by Lo-Dash are similar to those in embedded Ruby - * (ERB). Change the following template settings to use alternative delimiters. - **/ - templateSettings: TemplateSettings; - } - - /** - * By default, the template delimiters used by Lo-Dash are similar to those in embedded Ruby - * (ERB). Change the following template settings to use alternative delimiters. - **/ - interface TemplateSettings { - /** - * The "escape" delimiter. - **/ - escape?: RegExp; - - /** - * The "evaluate" delimiter. - **/ - evaluate?: RegExp; - - /** - * An object to import into the template as local variables. - **/ - imports?: Dictionary; - - /** - * The "interpolate" delimiter. - **/ - interpolate?: RegExp; - - /** - * Used to reference the data object in the template text. - **/ - variable?: string; - } - - /** - * Creates a cache object to store key/value pairs. - */ - interface MapCache { - /** - * Removes `key` and its value from the cache. - * @param key The key of the value to remove. - * @return Returns `true` if the entry was removed successfully, else `false`. - */ - delete(key: string): boolean; - - /** - * Gets the cached value for `key`. - * @param key The key of the value to get. - * @return Returns the cached value. - */ - get(key: string): any; - - /** - * Checks if a cached value for `key` exists. - * @param key The key of the entry to check. - * @return Returns `true` if an entry for `key` exists, else `false`. - */ - has(key: string): boolean; - - /** - * Sets `value` to `key` of the cache. - * @param key The key of the value to cache. - * @param value The value to cache. - * @return Returns the cache object. - */ - set(key: string, value: any): _.Dictionary; - } - - interface LoDashWrapperBase { } - - interface LoDashImplicitWrapperBase extends LoDashWrapperBase { } - - interface LoDashExplicitWrapperBase extends LoDashWrapperBase { } - - interface LoDashImplicitWrapper extends LoDashImplicitWrapperBase> { } - - interface LoDashExplicitWrapper extends LoDashExplicitWrapperBase> { } - - interface LoDashImplicitStringWrapper extends LoDashImplicitWrapper { } - - interface LoDashExplicitStringWrapper extends LoDashExplicitWrapper { } - - interface LoDashImplicitObjectWrapper extends LoDashImplicitWrapperBase> { } - - interface LoDashExplicitObjectWrapper extends LoDashExplicitWrapperBase> { } - - interface LoDashImplicitArrayWrapper extends LoDashImplicitWrapperBase> { - pop(): T; - push(...items: T[]): LoDashImplicitArrayWrapper; - shift(): T; - sort(compareFn?: (a: T, b: T) => number): LoDashImplicitArrayWrapper; - splice(start: number): LoDashImplicitArrayWrapper; - splice(start: number, deleteCount: number, ...items: any[]): LoDashImplicitArrayWrapper; - unshift(...items: T[]): LoDashImplicitArrayWrapper; - } - - interface LoDashExplicitArrayWrapper extends LoDashExplicitWrapperBase> { } - - interface LoDashImplicitNumberArrayWrapper extends LoDashImplicitArrayWrapper
${this.properties.description}
${selectedDataTypeTitle}