This app provides monitoring and information features for the common freifunk user and the technical stuff of a freifunk community.
Code base is taken from a TUM Practical Course project and added here to see if Freifunk Altdorf can use it.
https://www.freifunk-altdorf.de
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
56 lines
1.1 KiB
56 lines
1.1 KiB
/** |
|
* Copyright (c) 2013-present, Facebook, Inc. |
|
* |
|
* This source code is licensed under the MIT license found in the |
|
* LICENSE file in the root directory of this source tree. |
|
* |
|
* @providesModule File |
|
* @flow |
|
* @format |
|
*/ |
|
'use strict'; |
|
|
|
const Blob = require('Blob'); |
|
|
|
const invariant = require('fbjs/lib/invariant'); |
|
|
|
import type {BlobOptions} from 'BlobTypes'; |
|
|
|
/** |
|
* The File interface provides information about files. |
|
*/ |
|
class File extends Blob { |
|
/** |
|
* Constructor for JS consumers. |
|
*/ |
|
constructor( |
|
parts: Array<Blob | string>, |
|
name: string, |
|
options?: BlobOptions, |
|
) { |
|
invariant( |
|
parts != null && name != null, |
|
'Failed to construct `File`: Must pass both `parts` and `name` arguments.', |
|
); |
|
|
|
super(parts, options); |
|
this.data.name = name; |
|
} |
|
|
|
/** |
|
* Name of the file. |
|
*/ |
|
get name(): string { |
|
invariant(this.data.name != null, 'Files must have a name set.'); |
|
return this.data.name; |
|
} |
|
|
|
/* |
|
* Last modified time of the file. |
|
*/ |
|
get lastModified(): number { |
|
return this.data.lastModified || 0; |
|
} |
|
} |
|
|
|
module.exports = File;
|
|
|