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

Test/create folder #86

Open
wants to merge 73 commits into
base: dev
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
73 commits
Select commit Hold shift + click to select a range
f946b0b
Add style to allow word to be break and wrap
JamieHo3312 Apr 18, 2016
6230d9c
Update the style to place in the middle of the table
JamieHo3312 Apr 18, 2016
3b1c6e8
Remove angular-breadcrumb & implement breadcrumb component
Apr 21, 2016
2f1e1dc
Add base style for display property
JamieHo3312 Apr 21, 2016
d0227f2
Fix flexbox type layout issues in IE10
JamieHo3312 Apr 21, 2016
ce606a8
Add list item style for file list
JamieHo3312 Apr 21, 2016
ef3ccc9
Design file list
JamieHo3312 Apr 21, 2016
e7ad670
Change the accent theme grey to indigo
JamieHo3312 Apr 21, 2016
b17959d
Add File component
Apr 21, 2016
0a18a11
Remove angular-breadcrumb from source code
Apr 21, 2016
9ea4a82
Add click event to bucket component
Apr 22, 2016
dfb26b3
Add sample view & service to file component
Apr 22, 2016
3146d6e
Rename utils to services
Apr 25, 2016
e782e35
Move natural sotr function to utils for reusable
Apr 25, 2016
55f211c
Replace upload and create folder icon
JamieHo3312 Apr 26, 2016
dd78031
Add dialog-footer and list-dialog style
JamieHo3312 Apr 27, 2016
57bc03a
Add the ui of upload file
JamieHo3312 Apr 27, 2016
7f836dd
Real api call
May 6, 2016
745928e
Merge remote-tracking branch 'jamie/feature/design-file-list' into fe…
May 6, 2016
ad02be3
Bind controller properties to view
May 6, 2016
6fc82ff
Update $file service
May 6, 2016
635cf94
Merge branch 'dev' into feature/implement-breadcrumb
May 16, 2016
ce3cdb1
fix bug in action-navbar.html
May 16, 2016
46cf39a
Merge branch 'dev' into feature/files-list-component
May 16, 2016
b521b34
Merge branch 'feature/implement-breadcrumb' into feature/files-list-c…
May 16, 2016
6679b83
Update file module
May 16, 2016
0a58ba8
Add ng-file-upload to dependencies
May 16, 2016
a356e99
Merge remote-tracking branch 'jamie/feature/design-upload-form' into …
May 16, 2016
d11309a
Add fileUpload to vendor and remove angular-breadcrumb
May 17, 2016
6b3d4af
Add filesize filter for size format
May 17, 2016
f71b02c
Add align style for set the vertical alignment
JamieHo3312 May 17, 2016
4fc9ec7
Add style for highlight the messages
JamieHo3312 May 17, 2016
37cc662
Design transfer view
JamieHo3312 May 17, 2016
5bbc8af
Update file.html
May 18, 2016
3d1c5c6
Remove unnecessary state and dependence in file.service.js
May 18, 2016
d90dfd1
Add file upload component
May 18, 2016
0054bd7
Add sign out handler
May 18, 2016
30283b7
Add method to Upload button in action navbar
May 18, 2016
f024de0
Fix breadcrumb bar
May 18, 2016
36bc561
Merge remote-tracking branch 'jamie/feature/design-transfer' into fea…
May 18, 2016
b8f6cff
Add transfer UI & update layout component
May 18, 2016
f46b0b1
Add transfer service
May 18, 2016
cf833f4
Remove transfer import in components/index.js
May 18, 2016
c931e89
Use boolean to control upadting status
May 18, 2016
48fadf8
Move toal size method to utils
May 18, 2016
d26b84b
Update method name
May 18, 2016
89fac79
Refactor upload component
May 18, 2016
35d0104
Merge branch 'feature/files-upload-component' into feature/transfer-c…
May 18, 2016
c0a0904
Update TokenInterceptor for other error handler
May 19, 2016
c98ab5b
Complete transfer component
May 19, 2016
f5df9e0
Fix bugs of toast message
May 19, 2016
e6b383d
Add $file dependence to $transfer
May 19, 2016
891ea2d
Update transfers & properties button of action navbar
May 19, 2016
3b7d1e4
Update properties event in actions button of action navbar
May 19, 2016
c8a9133
Format the file list for handle download
May 19, 2016
dc36651
Fix bugs when response files is null
May 19, 2016
3881496
Keep the previous bucket length of breadcrumb
May 19, 2016
34c9390
Add file download method
May 19, 2016
61f2848
Fix bugs of paths property in upload service
May 19, 2016
a14c4ad
Rename folders to prefix and make it as string
May 20, 2016
b853db7
Use html5 download api to download file
May 20, 2016
cd3a9b1
Refactor file service
May 23, 2016
a3a9bde
Add error handler when the download file not exist
May 23, 2016
24dcf80
Fix bug when file size small than 1024 bytes
May 20, 2016
67bed8a
Fix bug when action navbar switch
May 20, 2016
1943d0e
Fix menu items of actions button
May 23, 2016
6598bb5
Initial the folder component
May 23, 2016
a2aa487
Add createFolder to folder service
May 23, 2016
0784947
Add folder support to file service
May 23, 2016
82eff42
Fix issue etag will be same string
May 25, 2016
3a8c75f
Merge branch 'feature/download-file-component' into feature/create-fo…
May 25, 2016
89fd0a4
The select item should be file that is downloadable
May 25, 2016
0180272
Add create folder component unit test
May 26, 2016
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Refactor upload component
Modify the state of upload service, because the privous are not useable
in transfer. All files(pending, uploading, success...) in state.files
now, and use `status` for control.

* Refactor state tree.
* Refactor methods.
* Update totalSize
  • Loading branch information
jigsawye committed May 18, 2016
commit 89fac79e9aa2168a37da29e9e412ec172dda8371
5 changes: 4 additions & 1 deletion src/components/file/upload/upload.controller.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,10 @@ export default class FileUploadController {

$scope.$watch(
() => $upload.state,
newVal => Object.assign(this, newVal)
newVal => Object.assign(this, {
...newVal,
files: newVal.files.filter(file => file.status === 'PENDING'),
})
, true);
}

Expand Down
10 changes: 5 additions & 5 deletions src/components/file/upload/upload.html
Original file line number Diff line number Diff line change
Expand Up @@ -41,15 +41,15 @@ <h2 translate>Upload Files</h2>
<md-divider></md-divider>

<md-list-item ng-repeat="file in upload.files">
<md-icon class="material-icons" ng-if="file.startWith('image/')">photo</md-icon>
<md-icon class="material-icons" ng-if="! file.startWith('image/')">insert_drive_file</md-icon>
<md-icon class="material-icons" ng-if="file.detail.type.startWith('image/')">photo</md-icon>
<md-icon class="material-icons" ng-if="! file.detail.type.startWith('image/')">insert_drive_file</md-icon>

<p class="flex-grow" ng-bind="file.name"></p>
<p class="flex-none" ng-bind="(file.size | filesize)"></p>
<p class="flex-grow" ng-bind="file.detail.name"></p>
<p class="flex-none" ng-bind="(file.detail.size | filesize)"></p>

<md-icon
class="material-icons md-warn md-secondary" aria-label="Remove File"
ng-click="upload.delete(file.name)" ng-disabled="@A.13"
ng-click="upload.delete(file.id)" ng-disabled="@A.13"
>clear</md-icon>
</md-list-item>

Expand Down
97 changes: 61 additions & 36 deletions src/components/file/upload/upload.servce.js
Original file line number Diff line number Diff line change
Expand Up @@ -18,21 +18,29 @@ export default class FileUploadService {
files: [],
size: 0,
uploading: false,
uploadingFiles: [],
};
}

select(selectFiles) {
const filterFiles = selectFiles.filter(selectFile =>
this.state.files.every(file => file.name !== selectFile.name)
);
const files = this.state.files.concat(filterFiles);
select(selectedFiles) {
const additionalFiles = selectedFiles.filter(selectedFile =>
this.state.files.every(({ detail, status }) =>
(detail.name === selectedFile.name && status !== 'PENDING') ||
(detail.name !== selectedFile.name && status === 'PENDING')
)
).map(detail => ({
id: Symbol('unique id'),
status: 'PENDING',
detail,
}));

const files = [...this.state.files, ...additionalFiles];

const size = totalSize(files);
this.state = { ...this.state, files, size };
}

delete(name) {
const files = this.state.files.filter(file => file.name !== name);
delete(id) {
const files = this.state.files.filter(file => file.id !== id);
const size = totalSize(files);

this.state = { ...this.state, files, size };
Expand All @@ -43,58 +51,76 @@ export default class FileUploadService {
}

abort() {
this.state.uploadingFiles.forEach(file => file.abort());
this.state.uploadingFiles = [];
this.state.files.forEach(file => file.upload.abort());
this.state.files = [];
}

findFileIndex(id) {
return this.state.files.findIndex(file => file.id === id);
}

upload() {
const { bucket, folders } = this.$file.paths;
const prefix = folders.length ? '' : `${folders.join('/')}/`;
const url = `${this.Config.API_URL}/v1/file/create`;

this.state.files.forEach(file =>
this.uploadFile(url, { bucket, prefix, file })
);
this.state = {
uploading: true,
files: this.state.files.map(file => ({
...file,
status: 'UPLOADING',
upload: this.uploadFile(file.id, {
bucket, prefix, file: file.detail,
}, url),
})),
};

this.closeDialog();
}

uploadFile(url, data) {
const { name } = data.file;
uploadFile(id, data, url) {
const upload = this.Upload.upload({ url, data });
this.state.uploadingFiles.push(upload);
this.state.uploading = true;

upload.then(
() => this.handleSuccess(name),
err => this.handleFailure(name, err),
evt => this.handleEvent(name, evt)
res => this.handleSuccess(id, res),
err => this.handleFailure(id, err),
evt => this.handleEvent(id, evt)
);

return upload;
}

handleEvent(name, evt) {
console.log(evt);
handleEvent(id, evt) {
const i = this.findFileIndex(id);
this.state.files[i].process = evt;
console.log(this.state.files[i].process);
console.log(this.state);
}

handleSuccess(name) {
this.removeUploadingFile(name);
handleSuccess(id, res) {
const i = this.findFileIndex(id);
this.state.files[i].status = 'UPLOADED';
this.updateUpdateStatus();
this.$file.getFiles();
this.$toast.show(`${name} is uploaded successfully!`);
console.log(res);
}

handleFailure(name, err) {
this.removeUploadingFile(name);
this.$toast.show(`${name} is uploaded failure! Error: ${err}`);
handleFailure(id, err) {
const i = this.findFileIndex(id);
this.state.files[i].status = 'FAILURE';
this.updateUpdateStatus();
console.log(err);
}

removeUploadingFile(name) {
this.state.uploadingFiles.filter(uploadingFile =>
uploadingFile.name !== name
);
removeUploadFile(id) {
const i = this.findFileIndex(id);
delete this.state.files[i];
}

if (! this.state.uploadingFiles.length) {
this.state.uploading = false;
}
updateUpdateStatus() {
this.state.uploading = this.state.files.every(
file => file.status === 'UPLOADING'
);
}

createDialog($event) {
Expand All @@ -110,7 +136,6 @@ export default class FileUploadService {

closeDialog() {
this.$mdDialog.cancel();
this.state.files = [];
this.state.size = 0;
}
}
2 changes: 1 addition & 1 deletion src/utils/totalSize.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,5 +5,5 @@
*/
export default files => files
.reduce((previous, current) =>
previous + current.size, 0
previous + current.detail.size, 0
);