From 0679f44dd6195cedeebbdf3da76092099577abcb Mon Sep 17 00:00:00 2001 From: Sebastian Sdorra Date: Wed, 5 Sep 2018 14:45:22 +0200 Subject: [PATCH] update scm-svn-plugin to use Image from ui-components and types from ui-types --- scm-plugins/scm-svn-plugin/.babelrc | 6 + scm-plugins/scm-svn-plugin/.eslintrc | 3 + scm-plugins/scm-svn-plugin/.flowconfig | 8 + .../flow-typed/npm/classnames_v2.x.x.js | 23 + .../flow-typed/npm/jest_v23.x.x.js | 1108 +++++++++++++++++ .../flow-typed/npm/moment_v2.3.x.js | 331 +++++ .../flow-typed/npm/react-jss_vx.x.x.js | 137 ++ scm-plugins/scm-svn-plugin/package.json | 1 + scm-plugins/scm-svn-plugin/pom.xml | 40 +- .../src/main/js/ProtocolInformation.js | 6 +- .../scm-svn-plugin/src/main/js/SvnAvatar.js | 6 +- .../scm-svn-plugin/src/main/js/index.js | 5 +- 12 files changed, 1665 insertions(+), 9 deletions(-) create mode 100644 scm-plugins/scm-svn-plugin/.babelrc create mode 100644 scm-plugins/scm-svn-plugin/.eslintrc create mode 100644 scm-plugins/scm-svn-plugin/.flowconfig create mode 100644 scm-plugins/scm-svn-plugin/flow-typed/npm/classnames_v2.x.x.js create mode 100644 scm-plugins/scm-svn-plugin/flow-typed/npm/jest_v23.x.x.js create mode 100644 scm-plugins/scm-svn-plugin/flow-typed/npm/moment_v2.3.x.js create mode 100644 scm-plugins/scm-svn-plugin/flow-typed/npm/react-jss_vx.x.x.js diff --git a/scm-plugins/scm-svn-plugin/.babelrc b/scm-plugins/scm-svn-plugin/.babelrc new file mode 100644 index 0000000000..a248d20409 --- /dev/null +++ b/scm-plugins/scm-svn-plugin/.babelrc @@ -0,0 +1,6 @@ +{ + "presets": ["@babel/preset-env", "@babel/preset-react", "@babel/preset-flow"], + "plugins": [ + "@babel/plugin-proposal-class-properties" + ] +} diff --git a/scm-plugins/scm-svn-plugin/.eslintrc b/scm-plugins/scm-svn-plugin/.eslintrc new file mode 100644 index 0000000000..13c5268429 --- /dev/null +++ b/scm-plugins/scm-svn-plugin/.eslintrc @@ -0,0 +1,3 @@ +{ + "extends": "@scm-manager/eslint-config" +} diff --git a/scm-plugins/scm-svn-plugin/.flowconfig b/scm-plugins/scm-svn-plugin/.flowconfig new file mode 100644 index 0000000000..7ede008602 --- /dev/null +++ b/scm-plugins/scm-svn-plugin/.flowconfig @@ -0,0 +1,8 @@ +[ignore] +.*/node_modules/module-deps/.* + +[include] + +[libs] + +[options] diff --git a/scm-plugins/scm-svn-plugin/flow-typed/npm/classnames_v2.x.x.js b/scm-plugins/scm-svn-plugin/flow-typed/npm/classnames_v2.x.x.js new file mode 100644 index 0000000000..2307243eeb --- /dev/null +++ b/scm-plugins/scm-svn-plugin/flow-typed/npm/classnames_v2.x.x.js @@ -0,0 +1,23 @@ +// flow-typed signature: cf86673cc32d185bdab1d2ea90578d37 +// flow-typed version: 614bf49aa8/classnames_v2.x.x/flow_>=v0.25.x + +type $npm$classnames$Classes = + | string + | { [className: string]: * } + | false + | void + | null; + +declare module "classnames" { + declare module.exports: ( + ...classes: Array<$npm$classnames$Classes | $npm$classnames$Classes[]> + ) => string; +} + +declare module "classnames/bind" { + declare module.exports: $Exports<"classnames">; +} + +declare module "classnames/dedupe" { + declare module.exports: $Exports<"classnames">; +} diff --git a/scm-plugins/scm-svn-plugin/flow-typed/npm/jest_v23.x.x.js b/scm-plugins/scm-svn-plugin/flow-typed/npm/jest_v23.x.x.js new file mode 100644 index 0000000000..23b66b07e5 --- /dev/null +++ b/scm-plugins/scm-svn-plugin/flow-typed/npm/jest_v23.x.x.js @@ -0,0 +1,1108 @@ +// flow-typed signature: f5a484315a3dea13d273645306e4076a +// flow-typed version: 7c5d14b3d4/jest_v23.x.x/flow_>=v0.39.x + +type JestMockFn, TReturn> = { + (...args: TArguments): TReturn, + /** + * An object for introspecting mock calls + */ + mock: { + /** + * An array that represents all calls that have been made into this mock + * function. Each call is represented by an array of arguments that were + * passed during the call. + */ + calls: Array, + /** + * An array that contains all the object instances that have been + * instantiated from this mock function. + */ + instances: Array + }, + /** + * Resets all information stored in the mockFn.mock.calls and + * mockFn.mock.instances arrays. Often this is useful when you want to clean + * up a mock's usage data between two assertions. + */ + mockClear(): void, + /** + * Resets all information stored in the mock. This is useful when you want to + * completely restore a mock back to its initial state. + */ + mockReset(): void, + /** + * Removes the mock and restores the initial implementation. This is useful + * when you want to mock functions in certain test cases and restore the + * original implementation in others. Beware that mockFn.mockRestore only + * works when mock was created with jest.spyOn. Thus you have to take care of + * restoration yourself when manually assigning jest.fn(). + */ + mockRestore(): void, + /** + * Accepts a function that should be used as the implementation of the mock. + * The mock itself will still record all calls that go into and instances + * that come from itself -- the only difference is that the implementation + * will also be executed when the mock is called. + */ + mockImplementation( + fn: (...args: TArguments) => TReturn + ): JestMockFn, + /** + * Accepts a function that will be used as an implementation of the mock for + * one call to the mocked function. Can be chained so that multiple function + * calls produce different results. + */ + mockImplementationOnce( + fn: (...args: TArguments) => TReturn + ): JestMockFn, + /** + * Accepts a string to use in test result output in place of "jest.fn()" to + * indicate which mock function is being referenced. + */ + mockName(name: string): JestMockFn, + /** + * Just a simple sugar function for returning `this` + */ + mockReturnThis(): void, + /** + * Accepts a value that will be returned whenever the mock function is called. + */ + mockReturnValue(value: TReturn): JestMockFn, + /** + * Sugar for only returning a value once inside your mock + */ + mockReturnValueOnce(value: TReturn): JestMockFn, + /** + * Sugar for jest.fn().mockImplementation(() => Promise.resolve(value)) + */ + mockResolvedValue(value: TReturn): JestMockFn>, + /** + * Sugar for jest.fn().mockImplementationOnce(() => Promise.resolve(value)) + */ + mockResolvedValueOnce(value: TReturn): JestMockFn>, + /** + * Sugar for jest.fn().mockImplementation(() => Promise.reject(value)) + */ + mockRejectedValue(value: TReturn): JestMockFn>, + /** + * Sugar for jest.fn().mockImplementationOnce(() => Promise.reject(value)) + */ + mockRejectedValueOnce(value: TReturn): JestMockFn> +}; + +type JestAsymmetricEqualityType = { + /** + * A custom Jasmine equality tester + */ + asymmetricMatch(value: mixed): boolean +}; + +type JestCallsType = { + allArgs(): mixed, + all(): mixed, + any(): boolean, + count(): number, + first(): mixed, + mostRecent(): mixed, + reset(): void +}; + +type JestClockType = { + install(): void, + mockDate(date: Date): void, + tick(milliseconds?: number): void, + uninstall(): void +}; + +type JestMatcherResult = { + message?: string | (() => string), + pass: boolean +}; + +type JestMatcher = (actual: any, expected: any) => JestMatcherResult; + +type JestPromiseType = { + /** + * Use rejects to unwrap the reason of a rejected promise so any other + * matcher can be chained. If the promise is fulfilled the assertion fails. + */ + rejects: JestExpectType, + /** + * Use resolves to unwrap the value of a fulfilled promise so any other + * matcher can be chained. If the promise is rejected the assertion fails. + */ + resolves: JestExpectType +}; + +/** + * Jest allows functions and classes to be used as test names in test() and + * describe() + */ +type JestTestName = string | Function; + +/** + * Plugin: jest-styled-components + */ + +type JestStyledComponentsMatcherValue = + | string + | JestAsymmetricEqualityType + | RegExp + | typeof undefined; + +type JestStyledComponentsMatcherOptions = { + media?: string; + modifier?: string; + supports?: string; +} + +type JestStyledComponentsMatchersType = { + toHaveStyleRule( + property: string, + value: JestStyledComponentsMatcherValue, + options?: JestStyledComponentsMatcherOptions + ): void, +}; + +/** + * Plugin: jest-enzyme + */ +type EnzymeMatchersType = { + toBeChecked(): void, + toBeDisabled(): void, + toBeEmpty(): void, + toBeEmptyRender(): void, + toBePresent(): void, + toContainReact(element: React$Element): void, + toExist(): void, + toHaveClassName(className: string): void, + toHaveHTML(html: string): void, + toHaveProp: ((propKey: string, propValue?: any) => void) & ((props: Object) => void), + toHaveRef(refName: string): void, + toHaveState: ((stateKey: string, stateValue?: any) => void) & ((state: Object) => void), + toHaveStyle: ((styleKey: string, styleValue?: any) => void) & ((style: Object) => void), + toHaveTagName(tagName: string): void, + toHaveText(text: string): void, + toIncludeText(text: string): void, + toHaveValue(value: any): void, + toMatchElement(element: React$Element): void, + toMatchSelector(selector: string): void +}; + +// DOM testing library extensions https://github.com/kentcdodds/dom-testing-library#custom-jest-matchers +type DomTestingLibraryType = { + toBeInTheDOM(): void, + toHaveTextContent(content: string): void, + toHaveAttribute(name: string, expectedValue?: string): void +}; + +// Jest JQuery Matchers: https://github.com/unindented/custom-jquery-matchers +type JestJQueryMatchersType = { + toExist(): void, + toHaveLength(len: number): void, + toHaveId(id: string): void, + toHaveClass(className: string): void, + toHaveTag(tag: string): void, + toHaveAttr(key: string, val?: any): void, + toHaveProp(key: string, val?: any): void, + toHaveText(text: string | RegExp): void, + toHaveData(key: string, val?: any): void, + toHaveValue(val: any): void, + toHaveCss(css: {[key: string]: any}): void, + toBeChecked(): void, + toBeDisabled(): void, + toBeEmpty(): void, + toBeHidden(): void, + toBeSelected(): void, + toBeVisible(): void, + toBeFocused(): void, + toBeInDom(): void, + toBeMatchedBy(sel: string): void, + toHaveDescendant(sel: string): void, + toHaveDescendantWithText(sel: string, text: string | RegExp): void +}; + + +// Jest Extended Matchers: https://github.com/jest-community/jest-extended +type JestExtendedMatchersType = { + /** + * Note: Currently unimplemented + * Passing assertion + * + * @param {String} message + */ + // pass(message: string): void; + + /** + * Note: Currently unimplemented + * Failing assertion + * + * @param {String} message + */ + // fail(message: string): void; + + /** + * Use .toBeEmpty when checking if a String '', Array [] or Object {} is empty. + */ + toBeEmpty(): void; + + /** + * Use .toBeOneOf when checking if a value is a member of a given Array. + * @param {Array.<*>} members + */ + toBeOneOf(members: any[]): void; + + /** + * Use `.toBeNil` when checking a value is `null` or `undefined`. + */ + toBeNil(): void; + + /** + * Use `.toSatisfy` when you want to use a custom matcher by supplying a predicate function that returns a `Boolean`. + * @param {Function} predicate + */ + toSatisfy(predicate: (n: any) => boolean): void; + + /** + * Use `.toBeArray` when checking if a value is an `Array`. + */ + toBeArray(): void; + + /** + * Use `.toBeArrayOfSize` when checking if a value is an `Array` of size x. + * @param {Number} x + */ + toBeArrayOfSize(x: number): void; + + /** + * Use `.toIncludeAllMembers` when checking if an `Array` contains all of the same members of a given set. + * @param {Array.<*>} members + */ + toIncludeAllMembers(members: any[]): void; + + /** + * Use `.toIncludeAnyMembers` when checking if an `Array` contains any of the members of a given set. + * @param {Array.<*>} members + */ + toIncludeAnyMembers(members: any[]): void; + + /** + * Use `.toSatisfyAll` when you want to use a custom matcher by supplying a predicate function that returns a `Boolean` for all values in an array. + * @param {Function} predicate + */ + toSatisfyAll(predicate: (n: any) => boolean): void; + + /** + * Use `.toBeBoolean` when checking if a value is a `Boolean`. + */ + toBeBoolean(): void; + + /** + * Use `.toBeTrue` when checking a value is equal (===) to `true`. + */ + toBeTrue(): void; + + /** + * Use `.toBeFalse` when checking a value is equal (===) to `false`. + */ + toBeFalse(): void; + + /** + * Use .toBeDate when checking if a value is a Date. + */ + toBeDate(): void; + + /** + * Use `.toBeFunction` when checking if a value is a `Function`. + */ + toBeFunction(): void; + + /** + * Use `.toHaveBeenCalledBefore` when checking if a `Mock` was called before another `Mock`. + * + * Note: Required Jest version >22 + * Note: Your mock functions will have to be asynchronous to cause the timestamps inside of Jest to occur in a differentJS event loop, otherwise the mock timestamps will all be the same + * + * @param {Mock} mock + */ + toHaveBeenCalledBefore(mock: JestMockFn): void; + + /** + * Use `.toBeNumber` when checking if a value is a `Number`. + */ + toBeNumber(): void; + + /** + * Use `.toBeNaN` when checking a value is `NaN`. + */ + toBeNaN(): void; + + /** + * Use `.toBeFinite` when checking if a value is a `Number`, not `NaN` or `Infinity`. + */ + toBeFinite(): void; + + /** + * Use `.toBePositive` when checking if a value is a positive `Number`. + */ + toBePositive(): void; + + /** + * Use `.toBeNegative` when checking if a value is a negative `Number`. + */ + toBeNegative(): void; + + /** + * Use `.toBeEven` when checking if a value is an even `Number`. + */ + toBeEven(): void; + + /** + * Use `.toBeOdd` when checking if a value is an odd `Number`. + */ + toBeOdd(): void; + + /** + * Use `.toBeWithin` when checking if a number is in between the given bounds of: start (inclusive) and end (exclusive). + * + * @param {Number} start + * @param {Number} end + */ + toBeWithin(start: number, end: number): void; + + /** + * Use `.toBeObject` when checking if a value is an `Object`. + */ + toBeObject(): void; + + /** + * Use `.toContainKey` when checking if an object contains the provided key. + * + * @param {String} key + */ + toContainKey(key: string): void; + + /** + * Use `.toContainKeys` when checking if an object has all of the provided keys. + * + * @param {Array.} keys + */ + toContainKeys(keys: string[]): void; + + /** + * Use `.toContainAllKeys` when checking if an object only contains all of the provided keys. + * + * @param {Array.} keys + */ + toContainAllKeys(keys: string[]): void; + + /** + * Use `.toContainAnyKeys` when checking if an object contains at least one of the provided keys. + * + * @param {Array.} keys + */ + toContainAnyKeys(keys: string[]): void; + + /** + * Use `.toContainValue` when checking if an object contains the provided value. + * + * @param {*} value + */ + toContainValue(value: any): void; + + /** + * Use `.toContainValues` when checking if an object contains all of the provided values. + * + * @param {Array.<*>} values + */ + toContainValues(values: any[]): void; + + /** + * Use `.toContainAllValues` when checking if an object only contains all of the provided values. + * + * @param {Array.<*>} values + */ + toContainAllValues(values: any[]): void; + + /** + * Use `.toContainAnyValues` when checking if an object contains at least one of the provided values. + * + * @param {Array.<*>} values + */ + toContainAnyValues(values: any[]): void; + + /** + * Use `.toContainEntry` when checking if an object contains the provided entry. + * + * @param {Array.} entry + */ + toContainEntry(entry: [string, string]): void; + + /** + * Use `.toContainEntries` when checking if an object contains all of the provided entries. + * + * @param {Array.>} entries + */ + toContainEntries(entries: [string, string][]): void; + + /** + * Use `.toContainAllEntries` when checking if an object only contains all of the provided entries. + * + * @param {Array.>} entries + */ + toContainAllEntries(entries: [string, string][]): void; + + /** + * Use `.toContainAnyEntries` when checking if an object contains at least one of the provided entries. + * + * @param {Array.>} entries + */ + toContainAnyEntries(entries: [string, string][]): void; + + /** + * Use `.toBeExtensible` when checking if an object is extensible. + */ + toBeExtensible(): void; + + /** + * Use `.toBeFrozen` when checking if an object is frozen. + */ + toBeFrozen(): void; + + /** + * Use `.toBeSealed` when checking if an object is sealed. + */ + toBeSealed(): void; + + /** + * Use `.toBeString` when checking if a value is a `String`. + */ + toBeString(): void; + + /** + * Use `.toEqualCaseInsensitive` when checking if a string is equal (===) to another ignoring the casing of both strings. + * + * @param {String} string + */ + toEqualCaseInsensitive(string: string): void; + + /** + * Use `.toStartWith` when checking if a `String` starts with a given `String` prefix. + * + * @param {String} prefix + */ + toStartWith(prefix: string): void; + + /** + * Use `.toEndWith` when checking if a `String` ends with a given `String` suffix. + * + * @param {String} suffix + */ + toEndWith(suffix: string): void; + + /** + * Use `.toInclude` when checking if a `String` includes the given `String` substring. + * + * @param {String} substring + */ + toInclude(substring: string): void; + + /** + * Use `.toIncludeRepeated` when checking if a `String` includes the given `String` substring the correct number of times. + * + * @param {String} substring + * @param {Number} times + */ + toIncludeRepeated(substring: string, times: number): void; + + /** + * Use `.toIncludeMultiple` when checking if a `String` includes all of the given substrings. + * + * @param {Array.} substring + */ + toIncludeMultiple(substring: string[]): void; +}; + +interface JestExpectType { + not: + & JestExpectType + & EnzymeMatchersType + & DomTestingLibraryType + & JestJQueryMatchersType + & JestStyledComponentsMatchersType + & JestExtendedMatchersType, + /** + * If you have a mock function, you can use .lastCalledWith to test what + * arguments it was last called with. + */ + lastCalledWith(...args: Array): void, + /** + * toBe just checks that a value is what you expect. It uses === to check + * strict equality. + */ + toBe(value: any): void, + /** + * Use .toBeCalledWith to ensure that a mock function was called with + * specific arguments. + */ + toBeCalledWith(...args: Array): void, + /** + * Using exact equality with floating point numbers is a bad idea. Rounding + * means that intuitive things fail. + */ + toBeCloseTo(num: number, delta: any): void, + /** + * Use .toBeDefined to check that a variable is not undefined. + */ + toBeDefined(): void, + /** + * Use .toBeFalsy when you don't care what a value is, you just want to + * ensure a value is false in a boolean context. + */ + toBeFalsy(): void, + /** + * To compare floating point numbers, you can use toBeGreaterThan. + */ + toBeGreaterThan(number: number): void, + /** + * To compare floating point numbers, you can use toBeGreaterThanOrEqual. + */ + toBeGreaterThanOrEqual(number: number): void, + /** + * To compare floating point numbers, you can use toBeLessThan. + */ + toBeLessThan(number: number): void, + /** + * To compare floating point numbers, you can use toBeLessThanOrEqual. + */ + toBeLessThanOrEqual(number: number): void, + /** + * Use .toBeInstanceOf(Class) to check that an object is an instance of a + * class. + */ + toBeInstanceOf(cls: Class<*>): void, + /** + * .toBeNull() is the same as .toBe(null) but the error messages are a bit + * nicer. + */ + toBeNull(): void, + /** + * Use .toBeTruthy when you don't care what a value is, you just want to + * ensure a value is true in a boolean context. + */ + toBeTruthy(): void, + /** + * Use .toBeUndefined to check that a variable is undefined. + */ + toBeUndefined(): void, + /** + * Use .toContain when you want to check that an item is in a list. For + * testing the items in the list, this uses ===, a strict equality check. + */ + toContain(item: any): void, + /** + * Use .toContainEqual when you want to check that an item is in a list. For + * testing the items in the list, this matcher recursively checks the + * equality of all fields, rather than checking for object identity. + */ + toContainEqual(item: any): void, + /** + * Use .toEqual when you want to check that two objects have the same value. + * This matcher recursively checks the equality of all fields, rather than + * checking for object identity. + */ + toEqual(value: any): void, + /** + * Use .toHaveBeenCalled to ensure that a mock function got called. + */ + toHaveBeenCalled(): void, + toBeCalled(): void; + /** + * Use .toHaveBeenCalledTimes to ensure that a mock function got called exact + * number of times. + */ + toHaveBeenCalledTimes(number: number): void, + toBeCalledTimes(number: number): void; + /** + * + */ + toHaveBeenNthCalledWith(nthCall: number, ...args: Array): void; + nthCalledWith(nthCall: number, ...args: Array): void; + /** + * + */ + toHaveReturned(): void; + toReturn(): void; + /** + * + */ + toHaveReturnedTimes(number: number): void; + toReturnTimes(number: number): void; + /** + * + */ + toHaveReturnedWith(value: any): void; + toReturnWith(value: any): void; + /** + * + */ + toHaveLastReturnedWith(value: any): void; + lastReturnedWith(value: any): void; + /** + * + */ + toHaveNthReturnedWith(nthCall: number, value: any): void; + nthReturnedWith(nthCall: number, value: any): void; + /** + * Use .toHaveBeenCalledWith to ensure that a mock function was called with + * specific arguments. + */ + toHaveBeenCalledWith(...args: Array): void, + toBeCalledWith(...args: Array): void, + /** + * Use .toHaveBeenLastCalledWith to ensure that a mock function was last called + * with specific arguments. + */ + toHaveBeenLastCalledWith(...args: Array): void, + lastCalledWith(...args: Array): void, + /** + * Check that an object has a .length property and it is set to a certain + * numeric value. + */ + toHaveLength(number: number): void, + /** + * + */ + toHaveProperty(propPath: string, value?: any): void, + /** + * Use .toMatch to check that a string matches a regular expression or string. + */ + toMatch(regexpOrString: RegExp | string): void, + /** + * Use .toMatchObject to check that a javascript object matches a subset of the properties of an object. + */ + toMatchObject(object: Object | Array): void, + /** + * Use .toStrictEqual to check that a javascript object matches a subset of the properties of an object. + */ + toStrictEqual(value: any): void, + /** + * This ensures that an Object matches the most recent snapshot. + */ + toMatchSnapshot(propertyMatchers?: {[key: string]: JestAsymmetricEqualityType}, name?: string): void, + /** + * This ensures that an Object matches the most recent snapshot. + */ + toMatchSnapshot(name: string): void, + + toMatchInlineSnapshot(snapshot?: string): void, + toMatchInlineSnapshot(propertyMatchers?: {[key: string]: JestAsymmetricEqualityType}, snapshot?: string): void, + /** + * Use .toThrow to test that a function throws when it is called. + * If you want to test that a specific error gets thrown, you can provide an + * argument to toThrow. The argument can be a string for the error message, + * a class for the error, or a regex that should match the error. + * + * Alias: .toThrowError + */ + toThrow(message?: string | Error | Class | RegExp): void, + toThrowError(message?: string | Error | Class | RegExp): void, + /** + * Use .toThrowErrorMatchingSnapshot to test that a function throws a error + * matching the most recent snapshot when it is called. + */ + toThrowErrorMatchingSnapshot(): void, + toThrowErrorMatchingInlineSnapshot(snapshot?: string): void, +} + +type JestObjectType = { + /** + * Disables automatic mocking in the module loader. + * + * After this method is called, all `require()`s will return the real + * versions of each module (rather than a mocked version). + */ + disableAutomock(): JestObjectType, + /** + * An un-hoisted version of disableAutomock + */ + autoMockOff(): JestObjectType, + /** + * Enables automatic mocking in the module loader. + */ + enableAutomock(): JestObjectType, + /** + * An un-hoisted version of enableAutomock + */ + autoMockOn(): JestObjectType, + /** + * Clears the mock.calls and mock.instances properties of all mocks. + * Equivalent to calling .mockClear() on every mocked function. + */ + clearAllMocks(): JestObjectType, + /** + * Resets the state of all mocks. Equivalent to calling .mockReset() on every + * mocked function. + */ + resetAllMocks(): JestObjectType, + /** + * Restores all mocks back to their original value. + */ + restoreAllMocks(): JestObjectType, + /** + * Removes any pending timers from the timer system. + */ + clearAllTimers(): void, + /** + * The same as `mock` but not moved to the top of the expectation by + * babel-jest. + */ + doMock(moduleName: string, moduleFactory?: any): JestObjectType, + /** + * The same as `unmock` but not moved to the top of the expectation by + * babel-jest. + */ + dontMock(moduleName: string): JestObjectType, + /** + * Returns a new, unused mock function. Optionally takes a mock + * implementation. + */ + fn, TReturn>( + implementation?: (...args: TArguments) => TReturn + ): JestMockFn, + /** + * Determines if the given function is a mocked function. + */ + isMockFunction(fn: Function): boolean, + /** + * Given the name of a module, use the automatic mocking system to generate a + * mocked version of the module for you. + */ + genMockFromModule(moduleName: string): any, + /** + * Mocks a module with an auto-mocked version when it is being required. + * + * The second argument can be used to specify an explicit module factory that + * is being run instead of using Jest's automocking feature. + * + * The third argument can be used to create virtual mocks -- mocks of modules + * that don't exist anywhere in the system. + */ + mock( + moduleName: string, + moduleFactory?: any, + options?: Object + ): JestObjectType, + /** + * Returns the actual module instead of a mock, bypassing all checks on + * whether the module should receive a mock implementation or not. + */ + requireActual(moduleName: string): any, + /** + * Returns a mock module instead of the actual module, bypassing all checks + * on whether the module should be required normally or not. + */ + requireMock(moduleName: string): any, + /** + * Resets the module registry - the cache of all required modules. This is + * useful to isolate modules where local state might conflict between tests. + */ + resetModules(): JestObjectType, + /** + * Exhausts the micro-task queue (usually interfaced in node via + * process.nextTick). + */ + runAllTicks(): void, + /** + * Exhausts the macro-task queue (i.e., all tasks queued by setTimeout(), + * setInterval(), and setImmediate()). + */ + runAllTimers(): void, + /** + * Exhausts all tasks queued by setImmediate(). + */ + runAllImmediates(): void, + /** + * Executes only the macro task queue (i.e. all tasks queued by setTimeout() + * or setInterval() and setImmediate()). + */ + advanceTimersByTime(msToRun: number): void, + /** + * Executes only the macro task queue (i.e. all tasks queued by setTimeout() + * or setInterval() and setImmediate()). + * + * Renamed to `advanceTimersByTime`. + */ + runTimersToTime(msToRun: number): void, + /** + * Executes only the macro-tasks that are currently pending (i.e., only the + * tasks that have been queued by setTimeout() or setInterval() up to this + * point) + */ + runOnlyPendingTimers(): void, + /** + * Explicitly supplies the mock object that the module system should return + * for the specified module. Note: It is recommended to use jest.mock() + * instead. + */ + setMock(moduleName: string, moduleExports: any): JestObjectType, + /** + * Indicates that the module system should never return a mocked version of + * the specified module from require() (e.g. that it should always return the + * real module). + */ + unmock(moduleName: string): JestObjectType, + /** + * Instructs Jest to use fake versions of the standard timer functions + * (setTimeout, setInterval, clearTimeout, clearInterval, nextTick, + * setImmediate and clearImmediate). + */ + useFakeTimers(): JestObjectType, + /** + * Instructs Jest to use the real versions of the standard timer functions. + */ + useRealTimers(): JestObjectType, + /** + * Creates a mock function similar to jest.fn but also tracks calls to + * object[methodName]. + */ + spyOn(object: Object, methodName: string, accessType?: "get" | "set"): JestMockFn, + /** + * Set the default timeout interval for tests and before/after hooks in milliseconds. + * Note: The default timeout interval is 5 seconds if this method is not called. + */ + setTimeout(timeout: number): JestObjectType +}; + +type JestSpyType = { + calls: JestCallsType +}; + +/** Runs this function after every test inside this context */ +declare function afterEach( + fn: (done: () => void) => ?Promise, + timeout?: number +): void; +/** Runs this function before every test inside this context */ +declare function beforeEach( + fn: (done: () => void) => ?Promise, + timeout?: number +): void; +/** Runs this function after all tests have finished inside this context */ +declare function afterAll( + fn: (done: () => void) => ?Promise, + timeout?: number +): void; +/** Runs this function before any tests have started inside this context */ +declare function beforeAll( + fn: (done: () => void) => ?Promise, + timeout?: number +): void; + +/** A context for grouping tests together */ +declare var describe: { + /** + * Creates a block that groups together several related tests in one "test suite" + */ + (name: JestTestName, fn: () => void): void, + + /** + * Only run this describe block + */ + only(name: JestTestName, fn: () => void): void, + + /** + * Skip running this describe block + */ + skip(name: JestTestName, fn: () => void): void +}; + +/** An individual test unit */ +declare var it: { + /** + * An individual test unit + * + * @param {JestTestName} Name of Test + * @param {Function} Test + * @param {number} Timeout for the test, in milliseconds. + */ + ( + name: JestTestName, + fn?: (done: () => void) => ?Promise, + timeout?: number + ): void, + /** + * each runs this test against array of argument arrays per each run + * + * @param {table} table of Test + */ + each( + table: Array> + ): ( + name: JestTestName, + fn?: (...args: Array) => ?Promise + ) => void, + /** + * Only run this test + * + * @param {JestTestName} Name of Test + * @param {Function} Test + * @param {number} Timeout for the test, in milliseconds. + */ + only( + name: JestTestName, + fn?: (done: () => void) => ?Promise, + timeout?: number + ): { + each( + table: Array> + ): ( + name: JestTestName, + fn?: (...args: Array) => ?Promise + ) => void, + }, + /** + * Skip running this test + * + * @param {JestTestName} Name of Test + * @param {Function} Test + * @param {number} Timeout for the test, in milliseconds. + */ + skip( + name: JestTestName, + fn?: (done: () => void) => ?Promise, + timeout?: number + ): void, + /** + * Run the test concurrently + * + * @param {JestTestName} Name of Test + * @param {Function} Test + * @param {number} Timeout for the test, in milliseconds. + */ + concurrent( + name: JestTestName, + fn?: (done: () => void) => ?Promise, + timeout?: number + ): void +}; +declare function fit( + name: JestTestName, + fn: (done: () => void) => ?Promise, + timeout?: number +): void; +/** An individual test unit */ +declare var test: typeof it; +/** A disabled group of tests */ +declare var xdescribe: typeof describe; +/** A focused group of tests */ +declare var fdescribe: typeof describe; +/** A disabled individual test */ +declare var xit: typeof it; +/** A disabled individual test */ +declare var xtest: typeof it; + +type JestPrettyFormatColors = { + comment: { close: string, open: string }, + content: { close: string, open: string }, + prop: { close: string, open: string }, + tag: { close: string, open: string }, + value: { close: string, open: string }, +}; + +type JestPrettyFormatIndent = string => string; +type JestPrettyFormatRefs = Array; +type JestPrettyFormatPrint = any => string; +type JestPrettyFormatStringOrNull = string | null; + +type JestPrettyFormatOptions = {| + callToJSON: boolean, + edgeSpacing: string, + escapeRegex: boolean, + highlight: boolean, + indent: number, + maxDepth: number, + min: boolean, + plugins: JestPrettyFormatPlugins, + printFunctionName: boolean, + spacing: string, + theme: {| + comment: string, + content: string, + prop: string, + tag: string, + value: string, + |}, +|}; + +type JestPrettyFormatPlugin = { + print: ( + val: any, + serialize: JestPrettyFormatPrint, + indent: JestPrettyFormatIndent, + opts: JestPrettyFormatOptions, + colors: JestPrettyFormatColors, + ) => string, + test: any => boolean, +}; + +type JestPrettyFormatPlugins = Array; + +/** The expect function is used every time you want to test a value */ +declare var expect: { + /** The object that you want to make assertions against */ + (value: any): + & JestExpectType + & JestPromiseType + & EnzymeMatchersType + & DomTestingLibraryType + & JestJQueryMatchersType + & JestStyledComponentsMatchersType + & JestExtendedMatchersType, + + /** Add additional Jasmine matchers to Jest's roster */ + extend(matchers: { [name: string]: JestMatcher }): void, + /** Add a module that formats application-specific data structures. */ + addSnapshotSerializer(pluginModule: JestPrettyFormatPlugin): void, + assertions(expectedAssertions: number): void, + hasAssertions(): void, + any(value: mixed): JestAsymmetricEqualityType, + anything(): any, + arrayContaining(value: Array): Array, + objectContaining(value: Object): Object, + /** Matches any received string that contains the exact expected string. */ + stringContaining(value: string): string, + stringMatching(value: string | RegExp): string, + not: { + arrayContaining: (value: $ReadOnlyArray) => Array, + objectContaining: (value: {}) => Object, + stringContaining: (value: string) => string, + stringMatching: (value: string | RegExp) => string, + }, +}; + +// TODO handle return type +// http://jasmine.github.io/2.4/introduction.html#section-Spies +declare function spyOn(value: mixed, method: string): Object; + +/** Holds all functions related to manipulating test runner */ +declare var jest: JestObjectType; + +/** + * The global Jasmine object, this is generally not exposed as the public API, + * using features inside here could break in later versions of Jest. + */ +declare var jasmine: { + DEFAULT_TIMEOUT_INTERVAL: number, + any(value: mixed): JestAsymmetricEqualityType, + anything(): any, + arrayContaining(value: Array): Array, + clock(): JestClockType, + createSpy(name: string): JestSpyType, + createSpyObj( + baseName: string, + methodNames: Array + ): { [methodName: string]: JestSpyType }, + objectContaining(value: Object): Object, + stringMatching(value: string): string +}; diff --git a/scm-plugins/scm-svn-plugin/flow-typed/npm/moment_v2.3.x.js b/scm-plugins/scm-svn-plugin/flow-typed/npm/moment_v2.3.x.js new file mode 100644 index 0000000000..c2786e87fd --- /dev/null +++ b/scm-plugins/scm-svn-plugin/flow-typed/npm/moment_v2.3.x.js @@ -0,0 +1,331 @@ +// flow-typed signature: 23b805356f90ad9384dd88489654e380 +// flow-typed version: e9374c5fe9/moment_v2.3.x/flow_>=v0.25.x + +type moment$MomentOptions = { + y?: number | string, + year?: number | string, + years?: number | string, + M?: number | string, + month?: number | string, + months?: number | string, + d?: number | string, + day?: number | string, + days?: number | string, + date?: number | string, + h?: number | string, + hour?: number | string, + hours?: number | string, + m?: number | string, + minute?: number | string, + minutes?: number | string, + s?: number | string, + second?: number | string, + seconds?: number | string, + ms?: number | string, + millisecond?: number | string, + milliseconds?: number | string +}; + +type moment$MomentObject = { + years: number, + months: number, + date: number, + hours: number, + minutes: number, + seconds: number, + milliseconds: number +}; + +type moment$MomentCreationData = { + input: string, + format: string, + locale: Object, + isUTC: boolean, + strict: boolean +}; + +type moment$CalendarFormat = string | ((moment: moment$Moment) => string); + +type moment$CalendarFormats = { + sameDay?: moment$CalendarFormat, + nextDay?: moment$CalendarFormat, + nextWeek?: moment$CalendarFormat, + lastDay?: moment$CalendarFormat, + lastWeek?: moment$CalendarFormat, + sameElse?: moment$CalendarFormat +}; + +declare class moment$LocaleData { + months(moment: moment$Moment): string, + monthsShort(moment: moment$Moment): string, + monthsParse(month: string): number, + weekdays(moment: moment$Moment): string, + weekdaysShort(moment: moment$Moment): string, + weekdaysMin(moment: moment$Moment): string, + weekdaysParse(weekDay: string): number, + longDateFormat(dateFormat: string): string, + isPM(date: string): boolean, + meridiem(hours: number, minutes: number, isLower: boolean): string, + calendar( + key: + | "sameDay" + | "nextDay" + | "lastDay" + | "nextWeek" + | "prevWeek" + | "sameElse", + moment: moment$Moment + ): string, + relativeTime( + number: number, + withoutSuffix: boolean, + key: "s" | "m" | "mm" | "h" | "hh" | "d" | "dd" | "M" | "MM" | "y" | "yy", + isFuture: boolean + ): string, + pastFuture(diff: any, relTime: string): string, + ordinal(number: number): string, + preparse(str: string): any, + postformat(str: string): any, + week(moment: moment$Moment): string, + invalidDate(): string, + firstDayOfWeek(): number, + firstDayOfYear(): number +} +declare class moment$MomentDuration { + humanize(suffix?: boolean): string, + milliseconds(): number, + asMilliseconds(): number, + seconds(): number, + asSeconds(): number, + minutes(): number, + asMinutes(): number, + hours(): number, + asHours(): number, + days(): number, + asDays(): number, + months(): number, + asWeeks(): number, + weeks(): number, + asMonths(): number, + years(): number, + asYears(): number, + add(value: number | moment$MomentDuration | Object, unit?: string): this, + subtract(value: number | moment$MomentDuration | Object, unit?: string): this, + as(unit: string): number, + get(unit: string): number, + toJSON(): string, + toISOString(): string, + isValid(): boolean +} +declare class moment$Moment { + static ISO_8601: string, + static ( + string?: string, + format?: string | Array, + strict?: boolean + ): moment$Moment, + static ( + string?: string, + format?: string | Array, + locale?: string, + strict?: boolean + ): moment$Moment, + static ( + initDate: ?Object | number | Date | Array | moment$Moment | string + ): moment$Moment, + static unix(seconds: number): moment$Moment, + static utc(): moment$Moment, + static utc(number: number | Array): moment$Moment, + static utc( + str: string, + str2?: string | Array, + str3?: string + ): moment$Moment, + static utc(moment: moment$Moment): moment$Moment, + static utc(date: Date): moment$Moment, + static parseZone(): moment$Moment, + static parseZone(rawDate: string): moment$Moment, + static parseZone( + rawDate: string, + format: string | Array + ): moment$Moment, + static parseZone( + rawDate: string, + format: string, + strict: boolean + ): moment$Moment, + static parseZone( + rawDate: string, + format: string, + locale: string, + strict: boolean + ): moment$Moment, + isValid(): boolean, + invalidAt(): 0 | 1 | 2 | 3 | 4 | 5 | 6, + creationData(): moment$MomentCreationData, + millisecond(number: number): this, + milliseconds(number: number): this, + millisecond(): number, + milliseconds(): number, + second(number: number): this, + seconds(number: number): this, + second(): number, + seconds(): number, + minute(number: number): this, + minutes(number: number): this, + minute(): number, + minutes(): number, + hour(number: number): this, + hours(number: number): this, + hour(): number, + hours(): number, + date(number: number): this, + dates(number: number): this, + date(): number, + dates(): number, + day(day: number | string): this, + days(day: number | string): this, + day(): number, + days(): number, + weekday(number: number): this, + weekday(): number, + isoWeekday(number: number): this, + isoWeekday(): number, + dayOfYear(number: number): this, + dayOfYear(): number, + week(number: number): this, + weeks(number: number): this, + week(): number, + weeks(): number, + isoWeek(number: number): this, + isoWeeks(number: number): this, + isoWeek(): number, + isoWeeks(): number, + month(number: number): this, + months(number: number): this, + month(): number, + months(): number, + quarter(number: number): this, + quarter(): number, + year(number: number): this, + years(number: number): this, + year(): number, + years(): number, + weekYear(number: number): this, + weekYear(): number, + isoWeekYear(number: number): this, + isoWeekYear(): number, + weeksInYear(): number, + isoWeeksInYear(): number, + get(string: string): number, + set(unit: string, value: number): this, + set(options: { [unit: string]: number }): this, + static max(...dates: Array): moment$Moment, + static max(dates: Array): moment$Moment, + static min(...dates: Array): moment$Moment, + static min(dates: Array): moment$Moment, + add( + value: number | moment$MomentDuration | moment$Moment | Object, + unit?: string + ): this, + subtract( + value: number | moment$MomentDuration | moment$Moment | string | Object, + unit?: string + ): this, + startOf(unit: string): this, + endOf(unit: string): this, + local(): this, + utc(): this, + utcOffset( + offset: number | string, + keepLocalTime?: boolean, + keepMinutes?: boolean + ): this, + utcOffset(): number, + format(format?: string): string, + fromNow(removeSuffix?: boolean): string, + from( + value: moment$Moment | string | number | Date | Array, + removePrefix?: boolean + ): string, + toNow(removePrefix?: boolean): string, + to( + value: moment$Moment | string | number | Date | Array, + removePrefix?: boolean + ): string, + calendar(refTime?: any, formats?: moment$CalendarFormats): string, + diff( + date: moment$Moment | string | number | Date | Array, + format?: string, + floating?: boolean + ): number, + valueOf(): number, + unix(): number, + daysInMonth(): number, + toDate(): Date, + toArray(): Array, + toJSON(): string, + toISOString( + keepOffset?: boolean + ): string, + toObject(): moment$MomentObject, + isBefore( + date?: moment$Moment | string | number | Date | Array, + units?: ?string + ): boolean, + isSame( + date?: moment$Moment | string | number | Date | Array, + units?: ?string + ): boolean, + isAfter( + date?: moment$Moment | string | number | Date | Array, + units?: ?string + ): boolean, + isSameOrBefore( + date?: moment$Moment | string | number | Date | Array, + units?: ?string + ): boolean, + isSameOrAfter( + date?: moment$Moment | string | number | Date | Array, + units?: ?string + ): boolean, + isBetween( + fromDate: moment$Moment | string | number | Date | Array, + toDate?: ?moment$Moment | string | number | Date | Array, + granularity?: ?string, + inclusion?: ?string + ): boolean, + isDST(): boolean, + isDSTShifted(): boolean, + isLeapYear(): boolean, + clone(): moment$Moment, + static isMoment(obj: any): boolean, + static isDate(obj: any): boolean, + static locale(locale: string, localeData?: Object): string, + static updateLocale(locale: string, localeData?: ?Object): void, + static locale(locales: Array): string, + locale(locale: string, customization?: Object | null): moment$Moment, + locale(): string, + static months(): Array, + static monthsShort(): Array, + static weekdays(): Array, + static weekdaysShort(): Array, + static weekdaysMin(): Array, + static months(): string, + static monthsShort(): string, + static weekdays(): string, + static weekdaysShort(): string, + static weekdaysMin(): string, + static localeData(key?: string): moment$LocaleData, + static duration( + value: number | Object | string, + unit?: string + ): moment$MomentDuration, + static isDuration(obj: any): boolean, + static normalizeUnits(unit: string): string, + static invalid(object: any): moment$Moment +} + +declare module "moment" { + declare module.exports: Class; +} diff --git a/scm-plugins/scm-svn-plugin/flow-typed/npm/react-jss_vx.x.x.js b/scm-plugins/scm-svn-plugin/flow-typed/npm/react-jss_vx.x.x.js new file mode 100644 index 0000000000..cf8abae155 --- /dev/null +++ b/scm-plugins/scm-svn-plugin/flow-typed/npm/react-jss_vx.x.x.js @@ -0,0 +1,137 @@ +// flow-typed signature: ba35d02d668b0d0a3e04a63a6847974e +// flow-typed version: <>/react-jss_v8.6.1/flow_v0.79.1 + +/** + * This is an autogenerated libdef stub for: + * + * 'react-jss' + * + * Fill this stub out by replacing all the `any` types. + * + * Once filled out, we encourage you to share your work with the + * community by sending a pull request to: + * https://github.com/flowtype/flow-typed + */ + +declare module 'react-jss' { + declare module.exports: any; +} + +/** + * We include stubs for each file inside this npm package in case you need to + * require those files directly. Feel free to delete any files that aren't + * needed. + */ +declare module 'react-jss/dist/react-jss' { + declare module.exports: any; +} + +declare module 'react-jss/dist/react-jss.min' { + declare module.exports: any; +} + +declare module 'react-jss/lib/compose' { + declare module.exports: any; +} + +declare module 'react-jss/lib/compose.test' { + declare module.exports: any; +} + +declare module 'react-jss/lib/contextTypes' { + declare module.exports: any; +} + +declare module 'react-jss/lib/createHoc' { + declare module.exports: any; +} + +declare module 'react-jss/lib/getDisplayName' { + declare module.exports: any; +} + +declare module 'react-jss/lib/index' { + declare module.exports: any; +} + +declare module 'react-jss/lib/index.test' { + declare module.exports: any; +} + +declare module 'react-jss/lib/injectSheet' { + declare module.exports: any; +} + +declare module 'react-jss/lib/injectSheet.test' { + declare module.exports: any; +} + +declare module 'react-jss/lib/jss' { + declare module.exports: any; +} + +declare module 'react-jss/lib/JssProvider' { + declare module.exports: any; +} + +declare module 'react-jss/lib/JssProvider.test' { + declare module.exports: any; +} + +declare module 'react-jss/lib/ns' { + declare module.exports: any; +} + +declare module 'react-jss/lib/propTypes' { + declare module.exports: any; +} + +// Filename aliases +declare module 'react-jss/dist/react-jss.js' { + declare module.exports: $Exports<'react-jss/dist/react-jss'>; +} +declare module 'react-jss/dist/react-jss.min.js' { + declare module.exports: $Exports<'react-jss/dist/react-jss.min'>; +} +declare module 'react-jss/lib/compose.js' { + declare module.exports: $Exports<'react-jss/lib/compose'>; +} +declare module 'react-jss/lib/compose.test.js' { + declare module.exports: $Exports<'react-jss/lib/compose.test'>; +} +declare module 'react-jss/lib/contextTypes.js' { + declare module.exports: $Exports<'react-jss/lib/contextTypes'>; +} +declare module 'react-jss/lib/createHoc.js' { + declare module.exports: $Exports<'react-jss/lib/createHoc'>; +} +declare module 'react-jss/lib/getDisplayName.js' { + declare module.exports: $Exports<'react-jss/lib/getDisplayName'>; +} +declare module 'react-jss/lib/index.js' { + declare module.exports: $Exports<'react-jss/lib/index'>; +} +declare module 'react-jss/lib/index.test.js' { + declare module.exports: $Exports<'react-jss/lib/index.test'>; +} +declare module 'react-jss/lib/injectSheet.js' { + declare module.exports: $Exports<'react-jss/lib/injectSheet'>; +} +declare module 'react-jss/lib/injectSheet.test.js' { + declare module.exports: $Exports<'react-jss/lib/injectSheet.test'>; +} +declare module 'react-jss/lib/jss.js' { + declare module.exports: $Exports<'react-jss/lib/jss'>; +} +declare module 'react-jss/lib/JssProvider.js' { + declare module.exports: $Exports<'react-jss/lib/JssProvider'>; +} +declare module 'react-jss/lib/JssProvider.test.js' { + declare module.exports: $Exports<'react-jss/lib/JssProvider.test'>; +} +declare module 'react-jss/lib/ns.js' { + declare module.exports: $Exports<'react-jss/lib/ns'>; +} +declare module 'react-jss/lib/propTypes.js' { + declare module.exports: $Exports<'react-jss/lib/propTypes'>; +} diff --git a/scm-plugins/scm-svn-plugin/package.json b/scm-plugins/scm-svn-plugin/package.json index cbe5d40842..98f0394833 100644 --- a/scm-plugins/scm-svn-plugin/package.json +++ b/scm-plugins/scm-svn-plugin/package.json @@ -1,6 +1,7 @@ { "name": "@scm-manager/scm-svn-plugin", "main": "src/main/js/index.js", + "license" : "BSD-3-Clause", "scripts": { "build": "ui-bundler plugin" }, diff --git a/scm-plugins/scm-svn-plugin/pom.xml b/scm-plugins/scm-svn-plugin/pom.xml index 701569e620..ebab79fcd9 100644 --- a/scm-plugins/scm-svn-plugin/pom.xml +++ b/scm-plugins/scm-svn-plugin/pom.xml @@ -54,7 +54,45 @@ - + + + com.github.sdorra + buildfrontend-maven-plugin + 2.1.0 + + + 8.11.4 + + + YARN + 1.9.4 + + + + + link-ui-types + process-sources + + install-link + + + @scm-manager/ui-types + + + + link-ui-components + process-sources + + install-link + + + @scm-manager/ui-components + + + + + + diff --git a/scm-plugins/scm-svn-plugin/src/main/js/ProtocolInformation.js b/scm-plugins/scm-svn-plugin/src/main/js/ProtocolInformation.js index 20c27e1ff2..ccff4118ba 100644 --- a/scm-plugins/scm-svn-plugin/src/main/js/ProtocolInformation.js +++ b/scm-plugins/scm-svn-plugin/src/main/js/ProtocolInformation.js @@ -1,9 +1,9 @@ //@flow -import React from 'react'; +import React from "react"; +import type { Repository } from "@scm-manager/ui-types"; -// TODO flow types ??? type Props = { - repository: Object + repository: Repository } class ProtocolInformation extends React.Component { diff --git a/scm-plugins/scm-svn-plugin/src/main/js/SvnAvatar.js b/scm-plugins/scm-svn-plugin/src/main/js/SvnAvatar.js index 4a6ba0fc94..06fc2454db 100644 --- a/scm-plugins/scm-svn-plugin/src/main/js/SvnAvatar.js +++ b/scm-plugins/scm-svn-plugin/src/main/js/SvnAvatar.js @@ -1,5 +1,6 @@ //@flow -import React from 'react'; +import React from "react"; +import { Image } from "@scm-manager/ui-components"; type Props = { }; @@ -7,8 +8,7 @@ type Props = { class SvnAvatar extends React.Component { render() { - // TODO we have to use Image from ui-components - return Subversion Logo; + return Subversion Logo; } } diff --git a/scm-plugins/scm-svn-plugin/src/main/js/index.js b/scm-plugins/scm-svn-plugin/src/main/js/index.js index 83e7bc6bde..9df7ef1649 100644 --- a/scm-plugins/scm-svn-plugin/src/main/js/index.js +++ b/scm-plugins/scm-svn-plugin/src/main/js/index.js @@ -1,6 +1,7 @@ +// @flow import { binder } from "@scm-manager/ui-extensions"; -import ProtocolInformation from './ProtocolInformation'; -import SvnAvatar from './SvnAvatar'; +import ProtocolInformation from "./ProtocolInformation"; +import SvnAvatar from "./SvnAvatar"; const svnPredicate = (props: Object) => { return props.repository && props.repository.type === "svn";