Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(frontend): update datahub-web client UI code #1806

Merged
merged 13 commits into from
Aug 26, 2020
Merged
Show file tree
Hide file tree
Changes from 6 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
The table of contents is too big for display.
Diff view
Diff view
  •  
  •  
  •  
7 changes: 7 additions & 0 deletions datahub-web/.eslintignore
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,13 @@
/bower.json.ember-try
/package.json.ember-try

# TODO [META-12204] Fix issues in datahub/pdsc that make us have to ignore the directory
# vendor generator for metadata-models TypeScript type definitions
**/@datahub/pdsc/

# generated metadata-models TypeScript type definitions
**/types/codegen/**/*.d.ts

# generated addon sources for publishing
**/@datahub/*/addon/**/*.js
**/@datahub/*/addon/**/*.js
Expand Down
28 changes: 22 additions & 6 deletions datahub-web/.eslintrc.js
Original file line number Diff line number Diff line change
Expand Up @@ -28,27 +28,32 @@ module.exports = {
'@typescript-eslint/interface-name-prefix': ['error', 'always'],
'@typescript-eslint/member-delimiter-style': 'error',
'@typescript-eslint/no-empty-interface': 'error',
'@typescript-eslint/no-angle-bracket-type-assertion': 'warn',
'@typescript-eslint/array-type': ['error', 'generic'],
'@typescript-eslint/consistent-type-assertions': 'warn',
'@typescript-eslint/array-type': ['error', { default: 'generic' }],
'@typescript-eslint/no-non-null-assertion': 'warn',
'@typescript-eslint/explicit-member-accessibility': 'off',
'@typescript-eslint/no-parameter-properties': 'off',
'@typescript-eslint/no-object-literal-type-assertion': 'warn',
'@typescript-eslint/explicit-function-return-type': 'warn',
'@typescript-eslint/ban-ts-ignore': 'warn',
'@typescript-eslint/no-empty-function': 'warn',
'@typescript-eslint/no-unused-vars': ['error', { argsIgnorePattern: '^_' }],
'prettier/prettier': ['error', { singleQuote: true, printWidth: 120 }],
'ember/no-ember-super-in-es-classes': 'error'
'ember/no-ember-super-in-es-classes': 'error',
'@datahub/no-addon-import': 'error',
'@datahub/no-linkedin-import': 'warn',
eqeqeq: ['error', 'always']
},
plugins: ['prettier', 'ember', '@typescript-eslint'],
plugins: ['prettier', 'ember', '@typescript-eslint', '@datahub'],
overrides: [
// node files
{
files: [
'**/.eslintrc.js',
'**/.template-lintrc.js',
'**/ember-cli-build.js',
'**/scripts/**/*.js',
'**/testem.js',
'**/blueprints/*/index.js',
'**/index.js',
'**/config/**/*.js',
'**/lib/*/**.js'
],
Expand All @@ -63,6 +68,17 @@ module.exports = {
rules: {
'@typescript-eslint/no-var-requires': 'off'
}
},
{
files: [
'@linkedin/**/*.ts',
'@linkedin/**/*.js',
'packages/data-portal-internal-clone/**/*.ts',
'packages/data-portal-internal-clone/**/*.js'
],
rules: {
'@datahub/no-linkedin-import': 'off'
}
}
]
};
13 changes: 8 additions & 5 deletions datahub-web/.eslintrc.precommit.js
Original file line number Diff line number Diff line change
@@ -1,20 +1,23 @@
module.exports = {
rules: {
'@typescript-eslint/no-angle-bracket-type-assertion': 'error',
'@typescript-eslint/consistent-type-assertions': 'error',
'@typescript-eslint/no-non-null-assertion': 'error',
'@typescript-eslint/no-object-literal-type-assertion': 'error',
'@typescript-eslint/explicit-function-return-type': 'error',
'@typescript-eslint/no-explicit-any': 'error'
'@typescript-eslint/no-explicit-any': 'error',
eqeqeq: ['error', 'always']
},
overrides: [
{
files: ['*-test.js', '*-test.ts', '**/mirage/**/*.ts'],
rules: {
'@typescript-eslint/no-angle-bracket-type-assertion': 'warn',
'@typescript-eslint/consistent-type-assertions': 'warn',
'@typescript-eslint/no-non-null-assertion': 'warn',
'@typescript-eslint/no-object-literal-type-assertion': 'warn',
'@typescript-eslint/explicit-function-return-type': 'warn',
'@typescript-eslint/no-explicit-any': 'warn'
},
files: ['*.js'],
rules: {
'@typescript-eslint/explicit-function-return-type': 'warn'
}
}
]
Expand Down
1 change: 1 addition & 0 deletions datahub-web/@datahub/data-models/.npmignore
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
/.ember-cli
/.eslintignore
/.eslintrc.js
/.git/
/.gitignore
/.watchmanconfig
/.travis.yml
Expand Down
22 changes: 14 additions & 8 deletions datahub-web/@datahub/data-models/.travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ language: node_js
node_js:
# we recommend testing addons with the same minimum supported node version as Ember CLI
# so that your addon works for all apps
- "6"
- '10'

sudo: false
dist: trusty
Expand All @@ -26,29 +26,35 @@ jobs:

include:
# runs linting and tests with current locked deps

- stage: "Tests"
name: "Tests"
- stage: 'Tests'
name: 'Tests'
install:
- yarn install --non-interactive
script:
- yarn lint:hbs
- yarn lint:js
- yarn test

- name: "Floating Dependencies"
- name: 'Floating Dependencies'
script:
- yarn test

- stage: 'Additional Tests'
name: 'Floating Dependencies'
install:
- npm install --no-package-lock
script:
- npm test

# we recommend new addons test the current and previous LTS
# as well as latest stable release (bonus points to beta/canary)
- stage: "Additional Tests"
env: EMBER_TRY_SCENARIO=ember-lts-2.16
- env: EMBER_TRY_SCENARIO=ember-lts-2.18
- env: EMBER_TRY_SCENARIO=ember-lts-3.8
- env: EMBER_TRY_SCENARIO=ember-lts-3.12
- env: EMBER_TRY_SCENARIO=ember-release
- env: EMBER_TRY_SCENARIO=ember-beta
- env: EMBER_TRY_SCENARIO=ember-canary
- env: EMBER_TRY_SCENARIO=ember-default-with-jquery
- env: EMBER_TRY_SCENARIO=ember-classic

before_install:
- curl -o- -L https://yarnpkg.com/install.sh | bash
Expand Down
2 changes: 1 addition & 1 deletion datahub-web/@datahub/data-models/LICENSE.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
The MIT License (MIT)
cptran777 marked this conversation as resolved.
Show resolved Hide resolved

Copyright (c) 2019
Copyright (c) 2020

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

Expand Down
45 changes: 21 additions & 24 deletions datahub-web/@datahub/data-models/README.md
Original file line number Diff line number Diff line change
@@ -1,51 +1,48 @@
@datahub/data-models
==============================================================================
# @datahub/data-models

[Short description of the addon.]
## Compatibility

Installation
------------------------------------------------------------------------------
- Ember.js v3.8 or above
- Ember CLI v2.13 or above
- Node.js v8 or above

## Installation

```
ember install @datahub/data-models
```


Usage
------------------------------------------------------------------------------
## Usage

[Longer description of how to use the addon in apps.]


Contributing
------------------------------------------------------------------------------
## Contributing

### Installation

* `git clone <repository-url>`
* `cd @datahub/data-models`
* `yarn install`
- `git clone <repository-url>`
- `cd @datahub/data-models`
- `yarn install`

### Linting

* `yarn lint:hbs`
* `yarn lint:js`
* `yarn lint:js --fix`
- `yarn lint:hbs`
- `yarn lint:js`
- `yarn lint:js --fix`

### Running tests

* `ember test` – Runs the test suite on the current Ember version
* `ember test --server` – Runs the test suite in "watch mode"
* `ember try:each` – Runs the test suite against multiple Ember versions
- `ember test` – Runs the test suite on the current Ember version
- `ember test --server` – Runs the test suite in "watch mode"
- `ember try:each` – Runs the test suite against multiple Ember versions

### Running the dummy application

* `ember serve`
* Visit the dummy application at [http://localhost:4200](http://localhost:4200).
- `ember serve`
- Visit the dummy application at [http://localhost:4200](http://localhost:4200).

For more information on using ember-cli, visit [https://ember-cli.com/](https://ember-cli.com/).

License
------------------------------------------------------------------------------
## License

This project is licensed under the [MIT License](LICENSE.md).
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
import { IInstitutionalMemory } from '@datahub/metadata-types/types/aspects/institutional-memory';
import { getJSON, postJSON } from '@datahub/utils/api/fetcher';
import buildUrl from '@datahub/utils/api/build-url';
import { ApiVersion, getApiRoot } from '@datahub/utils/api/shared';

/**
* Constructs the url for institutional memory
* @param {string} urn - the urn for the entity
*/
const institutionalMemoryByUrn = (urn: string, entityType: string): string =>
buildUrl(`${getApiRoot(ApiVersion.v2)}/institutionalmemory`, { urn, type: entityType });

/**
* Fetches the list of wiki-type url links to documents related to an entity
* @param {string} urn - urn for the entity
*/
export const readInstitutionalMemory = (
urn: string,
entityType: string
): Promise<{ elements: Array<IInstitutionalMemory> }> => getJSON({ url: institutionalMemoryByUrn(urn, entityType) });

/**
* Returns a view of the full list of wiki-type url links to documents related to an entity. This should be how the
* list appears after any changes by the user (add or delete)
* @param {string} urn - urn for the entity
* @param {Array<IInstitutionalMemory>} wikiLinks - related links snapshot
*/
export const writeInstitutionalMemory = (
urn: string,
entityType: string,
wikiLinks: Array<IInstitutionalMemory>
): Promise<void> =>
postJSON({
url: institutionalMemoryByUrn(urn, entityType),
data: { elements: wikiLinks }
});
107 changes: 107 additions & 0 deletions datahub-web/@datahub/data-models/addon/api/common/social-actions.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,107 @@
import { DataModelName } from '@datahub/data-models/constants/entity';
import { getApiRoot, ApiVersion } from '@datahub/utils/api/shared';
import { getJSON, postJSON } from '@datahub/utils/api/fetcher';
import {
ILikesAspect,
ILikeAction,
IFollowsAspect,
IFollowerType
} from '@datahub/metadata-types/types/aspects/social-actions';
import { encodeUrn } from '@datahub/utils/validators/urn';

/**
* Creates a url for a specific entity by urn and the social action we are constructing
* @param {DataModelName} entityType - the type of entity for which we are making this request
* @param {string} urn - identifier for the specific entity for which we want to construct the url
* @param {string} action - the kind of action we are creating
*/
const getSocialActionsUrl = (entityType: DataModelName, urn: string, action: string): string =>
`${getApiRoot(ApiVersion.v2)}/${entityType}/${encodeUrn(urn)}/${action}`;

/**
* Using the socialActionsUrl as a base, create a function that constructs one specifically for
* like actions
* @param {DataModelName} entityType - type of entity for which we want to construct this url
* @param {string} urn - urn identifier for the specific entity for which we are constructing the url
*/
const getLikeActionsUrl = (entityType: DataModelName, urn: string): string =>
getSocialActionsUrl(entityType, urn, 'likes');

/**
* Given a Likes aspect from the backend, returns the actual like actions related to that aspect
* @param actions - the list of like actions that are retrieved from the api
*/
const getLikeActionsFromAspect = ({ actions }: ILikesAspect): Array<ILikeAction> => actions;

/**
* Given an entity type and urn, construct a getter for which to retrieve likes information
* @param {DataModelName} entityType - the type of entity for which we want to read like information
* @param {string} urn - the identifier for the entity for which we want to read like information
*/
export const readLikesForEntity = (entityType: DataModelName, urn: string): Promise<Array<ILikeAction>> =>
getJSON({ url: getLikeActionsUrl(entityType, urn) }).then(getLikeActionsFromAspect);

/**
* Given an entity type and urn, post an update request that adds the user to the list of those who
* like the specified entity
* @param {DataModelName} entityType - the type of entity for which we want to add a like
* @param {string} urn - the identifier for the entity to which to add the user's like action
* @return an updated likes aspect for the entity
*/
export const addLikeForEntity = (entityType: DataModelName, urn: string): Promise<Array<ILikeAction>> =>
postJSON({ url: `${getLikeActionsUrl(entityType, urn)}/add`, data: {} }).then(getLikeActionsFromAspect);

/**
* Given an entity type and urn, post an update request that removes the user to the list of those
* who like the specified entity
* @param {DataModelName} entityType - the type of entity for which we want to add a like
* @param {string} urn - the identifier for teh entity to which to add the user's like action
* @return an updated likes aspect for the entity
*/
export const removeLikeForEntity = (entityType: DataModelName, urn: string): Promise<Array<ILikeAction>> =>
postJSON({ url: `${getLikeActionsUrl(entityType, urn)}/remove`, data: {} }).then(getLikeActionsFromAspect);

/**
* Using the socialActionsUrl as a base, create a function that constructs one specifically for
* follow actions
* @param {DataModelName} entityType - the type of entity for which we want to construct this urn
* @param {string} urn - urn identifier for the specific entity instance for which we are
* constructing the url
*/
const getFollowActionsUrl = (entityType: DataModelName, urn: string): string =>
getSocialActionsUrl(entityType, urn, 'follows');

/**
* Given the followers aspect from the API response, provided as a convenience function we return
* objects representing the followers themselves
* @param {Array<IFollowAction>} followers - the list of followers presented as
* FollowAction objects
*/
const getFollowersFromAspect = ({ followers }: IFollowsAspect): Array<IFollowerType> =>
followers.map(({ follower }): IFollowerType => follower);

/**
* Given an entity type and urn, construct a getter for which to retrieve follows information
* @param {DataModelName} entityType - the type of entity for which we want to read follow information
* @param {string} urn - the identifier for the entity for which we want to read follow information
*/
export const readFollowsForEntity = (entityType: DataModelName, urn: string): Promise<Array<IFollowerType>> =>
getJSON({ url: getFollowActionsUrl(entityType, urn) }).then(getFollowersFromAspect);

/**
* Given an entity type and urn, construct a getter for which to add the user as a follower
* @param {DataModelName} entityType - the type of entity for which we want to add the user as a follower
* @param {string} urn - the identifier for the entity for which we want to update follow information
* @return an updated follow aspect for the entity, if successful
*/
export const addFollowForEntity = (entityType: DataModelName, urn: string): Promise<Array<IFollowerType>> =>
postJSON({ url: `${getFollowActionsUrl(entityType, urn)}/add`, data: {} }).then(getFollowersFromAspect);

/**
* Given an entity type and urn, construct a getter for which to remove the user as a follower
* @param {DataModelName} entityType - the type of entity for which we want to remove the user as a follower
* @param {string} urn - the identifier for the entity for which we want to update follow information
* @return an updated follow aspect for the entity, if successful
*/
export const removeFollowForEntity = (entityType: DataModelName, urn: string): Promise<Array<IFollowerType>> =>
postJSON({ url: `${getFollowActionsUrl(entityType, urn)}/remove`, data: {} }).then(getFollowersFromAspect);
Loading